36,6 → 36,7 |
self::parserFichierIni($chemin_config_defaut_appli); |
|
// Chargement des fichiers config.ini contextuels |
|
if (PHP_SAPI == 'cli') {// mode console |
foreach ($_SERVER['argv'] as $cle => $valeur) { |
if ($valeur == '-contexte') { |
49,13 → 50,15 |
chargerFichierContexte('papyrus'); |
} |
// Via le fichie .ini par défaut de l'appli |
if (Config::existe('info.contexte')) { |
if (Config::existeValeur('info.contexte', self::$parametres)) { |
chargerFichierContexte(Config::get('info.contexte')); |
} |
|
// Chargement du contexte présent dans le GET |
if (isset($_GET['contexte'])) { |
chargerFichierContexte($_GET['contexte']); |
} |
|
// Chargement du contexte présent dans le POST |
if (isset($_POST['contexte'])) { |
chargerFichierContexte($_POST['contexte']); |
84,23 → 87,10 |
self::$parametres = array_merge(self::$parametres, $ini); |
} |
|
public static function charger($fichier_ini) { |
self::verifierCreationInstance(); |
return self::parserFichierIni($fichier_ini); |
} |
|
public static function get($param = null) { |
$retour = null; |
self::verifierCreationInstance(); |
private static function getValeur($param, $config) { |
if ($param === null) { |
$retour = self::$parametres; |
return null; |
} else { |
$retour = self::getValeur($param, self::$parametres); |
} |
return $retour; |
} |
|
private static function getValeur($param, $config) { |
if (strpos($param, '.') !== false) { |
$pieces = explode('.', $param, 2); |
if (strlen($pieces[0]) && strlen($pieces[1])) { |
117,11 → 107,11 |
} |
return null; |
} |
} |
|
public static function existe($param) { |
private static function existeValeur($param, $config) { |
$retour = false; |
self::verifierCreationInstance(); |
if (self::getValeur($param, self::$parametres) !== null) { |
if (self::getValeur($param, $config) !== null) { |
$retour = true; |
} |
return $retour; |
174,7 → 164,7 |
private static function evaluerReferences(&$config, $cle) { |
if (preg_match_all('/{ref:([A-Za-z0-9_-]+)}/', $config[$cle], $correspondances, PREG_SET_ORDER)) { |
foreach ($correspondances as $ref) { |
$config[$cle] = str_replace($ref[0], self::getValeur($ref[1], self::$parametres), $config[$cle]); |
$config[$cle] = str_replace($ref[0], self::getValeur($ref[1], $config), $config[$cle]); |
} |
} |
} |
184,5 → 174,20 |
eval('$config["'.$cle.'"] = '.$correspondances[1].';'); |
} |
} |
|
public static function charger($fichier_ini) { |
self::verifierCreationInstance(); |
return self::parserFichierIni($fichier_ini); |
} |
|
public static function get($param = null) { |
self::verifierCreationInstance(); |
return self::getValeur($param, self::$parametres);; |
} |
|
public static function existe($param) { |
self::verifierCreationInstance(); |
return self::existeValeur($param, self::$parametres); |
} |
} |
?> |