Subversion Repositories Applications.framework

Rev

Rev 98 | Rev 120 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 98 Rev 105
Line 1... Line 1...
1
<?php
1
<?php
-
 
2
// declare(encoding='UTF-8');
2
/**
3
/**
3
 * Classe registre, qui permet un accès à différentes variables à travers les autres classes.
4
 * Classe registre, qui permet un accès à différentes variables à travers les autres classes.
4
 * C'est un singleton
5
 * C'est un singleton
5
 */
6
 * 
-
 
7
* PHP Version 5 
-
 
8
* 
-
 
9
* @category  Class
-
 
10
* @package   Framework
-
 
11
* @author    Jean-Pascal Milcent <jmp@tela-botanica.org>
-
 
12
* @copyright 2009 Tela-Botanica
-
 
13
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL  
-
 
14
* @license   http://www.gnu.org/licenses/gpl.html Licence GNU-GPL  
-
 
15
* @version   SVN: $$Id: Registre.php 105 2009-08-31 15:25:05Z aurelien $$ 
-
 
16
* @link      /doc/framework/ 
-
 
17
* 
-
 
18
*/
6
class Registre {
19
class Registre {
Line 7... Line 20...
7
 
20
 
8
	/**
21
	/**
9
	 * Tableau associatif stockant les variables
22
	 * Tableau associatif stockant les variables
10
	 */
23
	 */
11
	private $stockage = array();
24
	private $stockage = array();
12
	/**
25
	/**
13
	 * La classe registre se contient elle-même, (pour le pattern singleton)
26
	 * La classe registre se contient elle-même, (pour le pattern singleton)
14
	 */
27
	 */
Line 15... Line 28...
15
	private static $registre;
28
	private static $registre;
16
 
29
 
17
	/**
30
	/**
18
	 * Constructeur par défaut, privé, car on accède à la classe par le getInstance
31
	 * Constructeur par défaut, privé, car on accède à la classe par le getInstance
19
	 */
32
	 */
Line 20... Line 33...
20
	private function __construct() {
33
	private function __construct() {
21
	}
34
	}
22
 
35
 
23
	/**
36
	/**
24
	 * Fonction qui renvoie l'instance de classe en assurant son unicité, c'est l'unique méthode qui doit être
37
	 * Fonction qui renvoie l'instance de classe en assurant son unicité, c'est l'unique méthode qui doit être
25
	 * utilisé pour récupérer l'objet Registre
38
	 * utilisée pour récupérer l'objet Registre
26
	 */
39
	 */
27
	public static function getInstance() {
40
	public static function getInstance() {
28
		if (self::$registre instanceof Registre) {
41
		if (self::$registre instanceof Registre) {
29
			return self::$registre;
42
			return self::$registre;
30
		}
43
		}
Line 31... Line 44...
31
		self::$registre = new Registre;
44
		self::$registre = new Registre;
32
	    return self::$registre;
45
	    return self::$registre;
33
	}
46
	}
34
 
47
 
35
	/**
48
	/**
36
	 * Ajoute un objet au tableau selon un intitulé donné
49
	 * Ajoute un objet au tableau selon un intitulé donné
37
	 * @param string l'intitulé sous lequel l'objet sera conservé
50
	 * @param string l'intitulé sous lequel l'objet sera conservé
38
	 * @param mixed l'objet à conserver
51
	 * @param mixed l'objet à conserver
39
	 */
52
	 */
40
	public function set($intitule, $objet) {
53
	public function set($intitule, $objet) {
41
		if (is_array($objet) && isset($this->stockage[$intitule])) {
54
		if (is_array($objet) && isset($this->stockage[$intitule])) {
42
			$this->stockage[$intitule] = array_merge((array) $this->stockage[$intitule], (array) $objet);
55
			$this->stockage[$intitule] = array_merge((array) $this->stockage[$intitule], (array) $objet);
43
			$message = "Le tableau $intitule présent dans le registre a été fusionné avec un nouveau tableau de même intitulé !";
56
			$message = "Le tableau $intitule présent dans le registre a été fusionné avec un nouveau tableau de même intitulé !";
44
			trigger_error($message, E_USER_WARNING);
57
			trigger_error($message, E_USER_WARNING);
Line 45... Line 58...
45
		} else {
58
		} else {
46
			$this->stockage[$intitule] = $objet;
59
			$this->stockage[$intitule] = $objet;
47
		}
60
		}
48
	}
61
	}
49
 
62
 
50
	/**
63
	/**
51
	 * Renvoie l'objet associé à l'intitulé donné en paramètre
64
	 * Renvoie l'objet associé à l'intitulé donné en paramètre
52
	 * @return mixed l'objet associé à l'intitulé ou null s'il n'est pas présent
65
	 * @return mixed l'objet associé à l'intitulé ou null s'il n'est pas présent
53
	 */
66
	 */
54
	public function get($intitule) {
67
	public function get($intitule) {
Line 55... Line 68...
55
		if (isset($this->stockage[$intitule])) {
68
		if (isset($this->stockage[$intitule])) {
56
			return $this->stockage[$intitule];
69
			return $this->stockage[$intitule];
57
		}
70
		}
58
		return null;
71
		return null;
59
	}
72
	}
60
 
73
 
61
	/**
74
	/**
62
	 * Détruit l'objet associé à l'intitulé, n'a pas d'effet si il n'y a pas d'objet associé
75
	 * Détruit l'objet associé à l'intitulé, n'a pas d'effet si il n'y a pas d'objet associé
Line 63... Line 76...
63
	 */
76
	 */
64
	public function detruire($intitule) {
77
	public function detruire($intitule) {
65
		if (isset($this->stockage[$intitule])) {
78
		if (isset($this->stockage[$intitule])) {
66
			unset($this->stockage[$intitule]);
79
			unset($this->stockage[$intitule]);
67
		}
80
		}
68
	}
81
	}
69
 
82
 
70
	/**
83
	/**