Subversion Repositories Applications.framework

Rev

Rev 153 | Rev 189 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

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