IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Remplacement fonction aggregate pour php 5 (runkit)


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 56
    Points : 34
    Points
    34
    Par défaut Remplacement fonction aggregate pour php 5 (runkit)
    Bonjour,

    Je suis actuellement un peu dans la misère du passage d'une application en php 4 sur un serveur php 5, et j'ai un soucis avec la fonction aggregate qui n'existe plus sous PHP5. En regardant un peu il semblerait qu'il faut que je passe par la lib runkit, mais voilà je ne vois pas du tout comment effectuer mes modifs...

    Je vous mets le code php 4, je ne vous mets pas tout mais juste le principal

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    class champ {
    	function getAlias() { return $this->name; }
    	function getTable() { return $this->table; }
    	function getLen() { return $this->max_length; }
    	function getType() { return $this->type; }
    	function isNotNull() { return !empty($this->not_null); }
    	function isPk() { return !empty($this->primary_key); }
    	function isUniqueKey() { return !empty($this->unique_key); }
    	function isMultipleKey() { return !empty($this->multiple_key); }
    	function isBlob() { return !empty($this->blob); }
    	function isUnsigned() { return !empty($this->unsigned); }
    	function isZerofill() { return !empty($this->zerofill); }
    	function isBinary() { return !empty($this->binary); }
    	function isEnum() { return !empty($this->enum); }
    	function isNumeric() { return !empty($this->numeric); }
    }
    class db{
    	var $link;
    	var $ok;
    	var $errno;
    	var $error;
    	var $sql;
    	var $auto_id;
    	var $affected_rows;
    	var $res;
    	var $log; // pour le suivi des erreurs par pear Log
    	var $logFile;
    	function db_result() {
    		$this->ok = true;
    		$this->errno = 0;
    		$this->error = "";
    		$this->sql = "";
    		$this->auto_id = 0;
    		$this->affected_rows = 0;
    	}
    	function db($new_link=false) {
    	    static $link;
    	    $this->initLogger();
    	    if (empty($link) || $new_link) {
    			require("vars_adm.php");
    			$this->link = mysql_connect($host, $user, $mdp, $new_link) or
    							die ("Impossible d'atteindre MySQL");
       			mysql_select_db($nomdb, $this->link) or
    		   					die ("Impossible d'accéder à ".$nomdb);
    			if (!$new_link) $link = $this->link;
    	    } else $this->link = $link;
    		$this->db_result();
    	}
    	function isOk() { return $this->ok; }
    	.....
    	function getSql() { return $this->sql; }
    	function getAutoId() { return $this->isOk() ? $this->auto_id : -1; }
    	function getAffectedRows() { return $this->isOk() ? $this->affected_rows : 0; }
    	function getNbRows() { return $this->isOk() ? mysql_num_rows($this->res) : 0; }
    	function getNbCols() { return $this->isOk() ? mysql_num_fields($this->res) : 0; }
    	function getNomCol($i) {
    		$field = mysql_fetch_field($this->res,$i);
    		aggregate($field,"champ");
    		return $field->getAlias();
    	}
    	function getTypeCol($i) {
    		$field = mysql_fetch_field($this->res,$i);
    		aggregate($field,"champ");
    		return $field->getType();
    	}
    Donc mon but est d'adapter les dernières fonctions, là il y en a que 2 j'ai bien plus que ça à modifier ...

    J'ai regarder les fonction du runkit, mais je n'ai pas compris le fonctionnement...

    Merci pour l'aide que vous pourriez m'apporter

  2. #2
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 56
    Points : 34
    Points
    34
    Par défaut
    J'ai résolu le pb

    j'ai juste ajouté un var $field dans la class champ qui sera initialisée par le $field de la fonction appelant le aggregate, enfin en gros ça donne ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    class champ {
     
    	var $field;
     
    	function Aggregate($champ){
    		$this->field=$champ;
    	}
     
    	function getAlias() { return $this->field->name; }
    	function getTable() { return $this->field->table; }
    ...
    }
     
    class db{
    ...
     
    function getNomCol($i) {
    		$field = mysql_fetch_field($this->res,$i);
    		$champ= new champ();
    		$champ->Aggregate($field);
    		//Aggregate($field,"champ");
    		return $champ->getAlias();
    	}
    ...
    }

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [SQL-Server] Probleme avec la fonction sqlsrv_query() pour php/sqlserver 2008
    Par lemzo84 dans le forum PHP & Base de données
    Réponses: 19
    Dernier message: 19/08/2011, 20h29
  2. Réponses: 1
    Dernier message: 08/06/2011, 11h09
  3. Réponses: 8
    Dernier message: 30/11/2009, 22h44
  4. équivalents de fonctions c# pour php
    Par zulot dans le forum Langage
    Réponses: 5
    Dernier message: 16/07/2007, 15h28
  5. Ajout de fonction C pour PHP
    Par syl2095 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 16/10/2006, 11h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo