Subversion Repositories Applications.framework

Rev

Rev 467 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 467 Rev 476
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Classe fournissant des informations au Framework sur l'application.
4
 * Classe fournissant des informations au Framework sur l'application.
5
 *
5
 *
6
 * PHP version 5
-
 
7
 *
-
 
8
 * @category Debogage
6
 * @category	PHP 5.2
9
 * @package Framework
7
 * @package		Framework
10
 // Auteur principal :
-
 
11
 * @author Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 // Autres auteurs :
9
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
13
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
10
 * @license		GNU-GPL-v3 <http://www.gnu.org/licenses/gpl.html>
14
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
11
 * @license		CECILL-v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt>
15
 * @version $Id: Application.php 456 2014-02-06 11:07:43Z jpm $
-
 
16
 * @copyright 1999-2009 Tela Botanica (accueil@tela-botanica.org)
-
 
17
 */
12
 */
18
class Application {
13
class Application {
19
 
14
 
20
	/**
15
	/**
21
	 * Tableau d'informations sur l'application
16
	 * Tableau d'informations sur l'application
22
	 */
17
	 */
23
	private static $info = null;
18
	private static $info = null;
24
	/**
19
	/**
25
	 * Chemin de base de l'application
20
	 * Chemin de base de l'application
26
	 */
21
	 */
27
	private static $chemin = null;
22
	private static $chemin = null;
28
 
23
 
29
	/**
24
	/**
30
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
25
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
31
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
26
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
32
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
27
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
33
	 */
28
	 */
34
	private static function initialiser() {
29
	private static function initialiser() {
35
		// Configuration du gestionnaire d'exception
30
		// Configuration du gestionnaire d'exception
36
		GestionnaireException::configurer();
31
		GestionnaireException::configurer();
37
		// Configuration du gestionnaire de logs
32
		// Configuration du gestionnaire de logs
38
		//Log::configurer();
33
		//Log::configurer();
39
	}
34
	}
40
 
35
 
41
	/**
36
	/**
42
	 * Permet d'indiquer le chemin de base de l'Application.
37
	 * Permet d'indiquer le chemin de base de l'Application.
43
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
38
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
44
	 * @param string $chemin_fichier_principal chemin de base
39
	 * @param string $chemin_fichier_principal chemin de base
45
	 */
40
	 */
46
	public static function setChemin($chemin_fichier_principal) {
41
	public static function setChemin($chemin_fichier_principal) {
47
		if (self::$chemin === null) {
42
		if (self::$chemin === null) {
48
			if (!file_exists($chemin_fichier_principal)) {
43
			if (!file_exists($chemin_fichier_principal)) {
49
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode set().", E_USER_ERROR);
44
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode set().", E_USER_ERROR);
50
			} else {
45
			} else {
51
				self::$chemin = dirname($chemin_fichier_principal).DS;
46
				self::$chemin = dirname($chemin_fichier_principal).DS;
52
				self::initialiser();
47
				self::initialiser();
53
			}
48
			}
54
		} else {
49
		} else {
55
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
50
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
56
		}
51
		}
57
	}
52
	}
58
 
53
 
59
	/**
54
	/**
60
	 * accesseur pour le chemin
55
	 * accesseur pour le chemin
61
	 * @return string le chemin
56
	 * @return string le chemin
62
	 */
57
	 */
63
	public static function getChemin() {
58
	public static function getChemin() {
64
		return self::$chemin;
59
		return self::$chemin;
65
	}
60
	}
66
 
61
 
67
	/** Le tableau des informations sur l'application possède les clés suivantes :
62
	/** Le tableau des informations sur l'application possède les clés suivantes :
68
	 * - nom : nom de l'application
63
	 * - nom : nom de l'application
69
	 * - abr : abréviation de l'application
64
	 * - abr : abréviation de l'application
70
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
65
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
71
	 *
66
	 *
72
	 * @param array $info tableau fournissant des informations sur l'application
67
	 * @param array $info tableau fournissant des informations sur l'application
73
	 * @return void
68
	 * @return void
74
	 */
69
	 */
75
	public static function setInfo($info) {
70
	public static function setInfo($info) {
76
		if (self::$info === null) {
71
		if (self::$info === null) {
77
			self::$info = $info;
72
			self::$info = $info;
78
		} else {
73
		} else {
79
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
74
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
80
		}
75
		}
81
	}
76
	}
82
 
77
 
83
	/**
78
	/**
84
	 * accesseur pour le tableau d'infos
79
	 * accesseur pour le tableau d'infos
85
	 * @param string $cle la clé à laquelle on veut accéder
80
	 * @param string $cle la clé à laquelle on veut accéder
86
	 */
81
	 */
87
	public static function getInfo($cle = null) {
82
	public static function getInfo($cle = null) {
88
		if ($cle !== null) {
83
		if ($cle !== null) {
89
			if (isset(self::$info[$cle])) {
84
			if (isset(self::$info[$cle])) {
90
				return self::$info[$cle];
85
				return self::$info[$cle];
91
			}
86
			}
92
		} else {
87
		} else {
93
			return self::$info;
88
			return self::$info;
94
		}
89
		}
95
	}
90
	}
96
}
91
}