Subversion Repositories Applications.framework

Rev

Rev 80 | Rev 105 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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