Subversion Repositories Applications.framework

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
5 aurelien 1
<?php
2
/**
3
 * Classe registre, qui permet un accès à différentes variables à travers les autres classes.
4
 * C'est un singleton
5
 */
6
class Registre {
7
 
8
	/**
9
	 * Tableau associatif stockant les variables
10
	 */
11
	private $aso_stock = array();
12
	/**
13
	 * La classe registre se contient elle-même, (pour le pattern singleton)
14
	 */
15
	private static $registre;
16
 
17
	/**
18
	 * Constructeur par défaut, privé, car on accède à la classe par le getInstance
19
	 */
20
	private function __construct()
21
	{
22
		$registre = $this;
23
	}
24
 
25
	/**
26
	 * Fonction qui renvoie l'instance de classe en assurant son unicité, c'est l'unique méthode qui doit être
27
	 * utilisé pour récupérer l'objet Registre
28
	 */
29
	public static function getInstance()
30
	{
31
		if (self::$registre instanceof Registre) {
32
			return self::$registre;
33
		}
34
		self::$registre = new Registre;
35
	    return self::$registre;
36
	}
37
 
38
	/**
39
	 * Ajoute un objet au tableau selon un intitulé donné
40
	 * @param string l'intitulé sous lequel l'objet sera conservé
41
	 * @param mixed l'objet à conserver
42
	 */
43
	function set($intitule, $objet)
44
	{
45
		if (is_array($objet) && isset($this->aso_stock[$intitule])) {
46
			$this->aso_stock[$intitule] = array_merge((array)$this->aso_stock[$intitule], (array)$objet);
47
			$message = "Le tableau $intitule présent dans le registre a été fusionné avec un nouveau tableau de même intitulé !";
48
			trigger_error($message, E_USER_WARNING);
49
		} else {
50
			$this->aso_stock[$intitule] = $objet;
51
		}
52
	}
53
 
54
	/**
55
	 * Renvoie l'objet associé à l'intitulé donné en paramètre
56
	 * @return mixed l'objet associé à l'intitulé ou null s'il n'est pas présent
57
	 */
58
	function get($intitule)
59
	{
60
		if (isset($this->aso_stock[$intitule])) {
61
			return $this->aso_stock[$intitule];
62
		}
63
		return null;
64
	}
65
 
66
	/**
67
	 * Détruit l'objet associé à l'intitulé, n'a pas d'effet si il n'y a pas d'objet associé
68
	 */
69
	function detruire($intitule)
70
	{
71
		if (isset($this->aso_stock[$intitule])) {
72
			unset($this->aso_stock[$intitule]);
73
		}
74
	}
75
 
76
	/**
77
	 * Teste si un objet est présent sous un intitulé donné
78
	 * @return boolean true si un objet associé à cet intitulé est présent, false sinon
79
	 */
80
	public function etrePresent($intitule)
81
	{
82
		if(isset($this->aso_stock[$intitule])){
83
			return true;
84
		}
85
		return false;
86
	}
87
}
88
?>