Subversion Repositories Applications.framework

Compare Revisions

Ignore whitespace Rev 116 → Rev 117

/trunk/framework/Config.php
34,8 → 34,9
// Chargement du fichier config.ini par défaut de l'application
$chemin_config_defaut_appli = self::$parametres['chemin_configurations'].sprintf(self::$parametres['fw_fichier_config'], '');
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,44 → 87,31
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);
if (strpos($param, '.') !== false) {
$pieces = explode('.', $param, 2);
if (strlen($pieces[0]) && strlen($pieces[1])) {
if (isset($config[$pieces[0]])) {
if (is_array($config[$pieces[0]])) {
return self::getValeur($pieces[1], $config[$pieces[0]]);
}
}
}
} else {
if (isset($config[$param])) {
return $config[$param];
}
}
return null;
}
return $retour;
}
 
private static function getValeur($param, $config) {
if (strpos($param, '.') !== false) {
$pieces = explode('.', $param, 2);
if (strlen($pieces[0]) && strlen($pieces[1])) {
if (isset($config[$pieces[0]])) {
if (is_array($config[$pieces[0]])) {
return self::getValeur($pieces[1], $config[$pieces[0]]);
}
}
}
} else {
if (isset($config[$param])) {
return $config[$param];
}
}
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);
}
}
?>