1) list($depot,$args) = $r; else { // si un seul argument, il faut trouver le depot $depot = cfg_charger_depot_args($args); } $depot = new cfg_depot($depot); $depot->charger_args($args); return $depot; } function cfg_charger_depot_args($args){ if ($args[0] == '~'){ return'tablepack'; } elseif ( (list($head, ) = explode('/',$args,2)) && (strpos($head,':') !== false)) { return'tablepack'; } else { if (strpos($args,'/') !== false) return'metapack'; else return'meta'; } } /** * cette classe charge les fonctions de lecture et ecriture d'un depot (dans depots/) * * Ces depots ont une version qui evoluera en fonction si des changements d'api apparaissent * * version 2 (fonctions) * - charger_args * - lire, ecrire, effacer * * @package plugins * @subpackage cfg */ class cfg_depot{ /** * Le nom de la classe du dépôt * @var string */ var $nom; /** * Le dépôt * @var Object */ var $depot; /* * * Constructeur de la classe * * 'depot' est le nom du fichier php stocke dans /depots/{depot}.php * qui contient une classe 'cfg_depot_{depot}' * * $params est un tableau de parametres passes a la classe cfg_depot_{depot} qui peut contenir : * * 'champs' => array( * 'nom'=>array( * 'balise' => 'select|textarea|input', // nom de la balise * 'type' => 'checkbox|hidden|text...', // type d'un input * 'tableau' => bool, // est-ce un champ tableau name="champ[]" ? * 'cfg' => 'xx', // classe css commencant par css_xx * 'id' => y, // cle du tableau 'champs_id' (emplacement qui possede ce champ) * ), * 'champs_id' => array( * cle => 'nom' // nom d'un champ de type id * ), * 'param' => array( * 'parametre_cfg' => 'valeur' // les parametres passes dans les formulaires cfg * ), * 'val' => array( * 'nom' => 'valeur' // les valeurs des champs sont stockes dedans * ) * ); * * * @param string $depot * @param Array $params */ function cfg_depot($depot='metapack', $params=array()){ if (!isset($params['param'])) { $params['param'] = array(); } include_spip('depots/'.$depot); if (!class_exists($class = 'cfg_depot_'.$depot)) { die("CFG ne trouve pas le dépot $depot"); } $this->depot = new $class($params); $this->version = $this->depot->version; $this->nom = $depot; } /** * ajoute les parametres transmis dans l'objet du depot * * @param Array $params */ function add_params($params){ foreach ($params as $o=>$v) { $this->depot->$o = $v; } } /** * récupérer les enregistrements des différents champs. * @param Array $params * @return Array */ function lire($params = array()){ $this->add_params($params); return $this->depot->lire(); // array($ok, $val, $messages) } /** * ecrit chaque enregistrement pour chaque champ. * @param Array $params * @return Array */ function ecrire($params = array()){ $this->add_params($params); return $this->depot->ecrire(); // array($ok, $val, $messages) } /** * supprime chaque enregistrement pour chaque champ. * @param Array $params * @return Array */ function effacer($params = array()){ $this->add_params($params); return $this->depot->effacer(); // array($ok, $val, $messages) } /** * Lecture de la configuration * * @param boolean $unserialize * @return string */ function lire_config($unserialize=true){ list($ok, $s) = $this->depot->lire($unserialize); if ($ok && ($nom = $this->nom_champ())) { return $s[$nom]; } elseif ($ok) { return $s; } } /** * enregistrer une configuration * * @param mixed $valeur * @return boolean */ function ecrire_config($valeur){ if ($nom = $this->nom_champ()) { $this->depot->val = array($nom=>$valeur); } else { $this->depot->val = $valeur; } list($ok, $s) = $this->depot->ecrire(); return $ok; } /** * supprimer une config * * @return boolean */ function effacer_config(){ if ($nom = $this->nom_champ()){ $this->depot->val[$nom] = false; } else { $this->depot->val = null; } list($ok, $s) = $this->depot->effacer(); return $ok; } /** * le nom d'un champ s'il est dans le dépôt * @return boolean|string */ function nom_champ(){ if (count($this->depot->champs)==1){ foreach ($this->depot->champs as $nom=>$def){ return $nom; } } return false; } /** * charge les arguments d'un lire/ecrire/effacer_config * dans le depot : lire_config($args = 'metapack::prefixe/casier/champ'); * * @param Array $args * @return boolean */ function charger_args($args){ if (method_exists($this->depot, 'charger_args')){ return $this->depot->charger_args($args); } return false; } } /** * Lecture de la configuration * * lire_config() permet de recuperer une config depuis le php
* memes arguments que la balise (forcement)
* $cfg: la config, lire_config('montruc') est un tableau
* lire_config('montruc/sub') est l'element "sub" de cette config * comme la balise pour ~, ~id_auteur ou table:id
* * $unserialize est mis par l'histoire, et affecte le depot 'meta' * * @param string $cfg la config * @param mixed $def un defaut optionnel * @param boolean $unserialize n'affecte que le depot 'meta' * @return string */ if (!function_exists('lire_config')) { function lire_config($cfg='', $def=null, $unserialize=true) { $depot = cfg_charger_depot($cfg); $r = $depot->lire_config($unserialize); if (is_null($r)) return $def; return $r; } } /** * enregistrer une configuration * * @param string $cfg * @param mixed $valeur * @return boolean */ if (!function_exists('ecrire_config')) { function ecrire_config($cfg='', $valeur=null){ $depot = cfg_charger_depot($cfg); return $depot->ecrire_config($valeur); } } /** * supprimer une config * * @param string $cfg * @return boolean */ if (!function_exists('effacer_config')) { function effacer_config($cfg=''){ $depot = cfg_charger_depot($cfg); return $depot->effacer_config(); } } ?>