Subversion Repositories Applications.framework

Rev

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

Rev 146 Rev 151
Line 1... Line 1...
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * classe Controleur, coeur d'une application, c'est normalement la seule classe d'une application
4
 * Classe Controleur, coeur d'une application, c'est normalement la seule classe d'une application
5
 * qui devrait être appelée de l'extérieur.
5
 * qui devrait être appelée de l'extérieur.
6
 * Elle est abstraite donc doit obligatoirement être étendue
6
 * Elle est abstraite donc doit obligatoirement être étendue.
7
 *
7
 *
8
 * PHP Version 5
-
 
9
 *
-
 
10
 * @category  Class
8
 * @category	php5
11
 * @package   Framework
9
 * @package		Framework
12
 * @author	aurelien <aurelien@tela-botanica.org>
10
 * @author		Aurélien PERONNET <aurelien@tela-botanica.org>
-
 
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
13
 * @copyright 2009 Tela-Botanica
12
 * @copyright	2009 Tela-Botanica
14
 * @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
13
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
15
 * @license   http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
14
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
16
 * @version   SVN: $$Id$$
15
 * @version		SVN: $$Id$$
17
 * @link	  /doc/framework/
16
 * @link		/doc/framework/
18
 *
17
 *
19
 */
18
 */
20
abstract class Controleur {
19
abstract class Controleur {
21
	/**
20
	/**
22
	 * Registre global, normalement accessible partout
21
	 * Registre global, normalement accessible partout
Line 72... Line 71...
72
				$sortie = new $nom_modele;
71
				$sortie = new $nom_modele;
73
			}
72
			}
74
		}
73
		}
75
		return $sortie;
74
		return $sortie;
76
	}
75
	}
77
 
76
	
78
	/**
77
	/**
79
	 * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données,
78
	 * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données,
80
	 * en extrait les variables, charge le squelette
-
 
81
	 * et cree une variable de classe contenant les deux combinés.
79
	 * en extrait les variables, charge le squelette et retourne le résultat des deux combinés.
82
	 *
80
	 *
83
	 * @param String $nom_squelette le nom du squelette
81
	 * @param String $nom_squelette le nom du squelette
84
	 * @param Array  $donnees	   un tableau associatif contenant les variables a injecter dans la vue
82
	 * @param Array  $donnees	   un tableau associatif contenant les variables a injecter dans la vue
85
	 *
83
	 *
86
	 * @return boolean false si la vue n'existe pas, rien sinon
84
	 * @return boolean false si la vue n'existe pas, sinon la chaine résultat.
87
	 */
85
	 */
88
	final protected function chargerVue($nom_squelette,$donnees) {
86
	final protected function getVue($nom_squelette, $donnees = array()) {
-
 
87
		$sortie = false;
89
		$chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
88
		$chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
-
 
89
		if (file_exists($chemin_squelette)) {
90
 
90
	
-
 
91
			// Extraction des variables du tableau de données
-
 
92
			extract($donnees);
-
 
93
			// Démarage de la bufferisation de sortie
-
 
94
			ob_start();
-
 
95
			// si les tags courts sont désactivés
-
 
96
			if ((bool) @ini_get('short_open_tag') === false) {
-
 
97
				// Remplacement des tags courts par la syntaxe classique avec echo
-
 
98
				echo eval('?>'.$this->traiterTagsCourts($chemin_squelette));
-
 
99
			} else {
-
 
100
				// sinon, on se contente d'inclure le squelette
91
		if (!file_exists($chemin_squelette)) {
101
				include $chemin_squelette;
-
 
102
			}
-
 
103
			// Récupèration du contenu du buffer
-
 
104
			$sortie = ob_get_contents();
-
 
105
			// Suppression du buffer
92
			return false ;
106
			@ob_end_clean();
93
		}
107
		}
94
 
108
		
95
		$donnees['base_url'] = $this->registre->get('base_url_application');
109
		// Retour du contenu
-
 
110
		return $sortie;
-
 
111
	}
96
 
112
	
-
 
113
	/**
97
		// on extrait les variables du tableau de données
114
	 * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données,
-
 
115
	 * en extrait les variables, charge le squelette et crée une variable de classe portant le nom du squelette 
98
		extract($donnees);
116
	 * contenant les deux combinés.
99
 
117
	 *
100
		// et on enclenche la bufferisation de sortie
118
	 * @param String $nom_squelette le nom du squelette
101
		ob_start();
119
	 * @param Array  $donnees	   un tableau associatif contenant les variables a injecter dans la vue
102
 
120
	 *
103
		// si les tags courts sont désactivés
121
	 * @return boolean false si la vue n'existe pas, sinon true.
-
 
122
	 */
104
		if ((bool) @ini_get('short_open_tag') === false) {
123
	final protected function chargerVue($nom_squelette, $donnees = array()) {
105
			// on remplace les tags par la syntaxe classique avec echo
124
		$sortie = false;
106
			echo eval('?>'.preg_replace("/;*\s*\?>/", "; ?>", str_replace('<?=', '<?php echo ', file_get_contents($chemin_squelette))));
125
		$rendu = $this->getVue($nom_squelette, $donnees);
107
		} else {
126
		if ($rendu !== false) {
108
			// sinon, on se contente d'inclure le squelette
127
			// Création d'une variable de classe contenant le rendu
109
			include $chemin_squelette;
128
			$this->$nom_squelette = $rendu;
-
 
129
			$sortie = true;
110
		}
130
		}
111
 
-
 
112
		// on récupère le buffer et on le vide
-
 
113
		$tampon = ob_get_contents();
-
 
114
		@ob_end_clean();
131
		return $sortie;
115
 
-
 
116
		// enfin on renvoie le contenu
-
 
117
		$this->$nom_squelette = $tampon;
-
 
118
	}
132
	}
119
 
133
	
120
	/**
134
	/**
-
 
135
	 * Fonction chargeant le contenu du squelette et remplaçant les tags court php (<?= ...) par un tag long avec echo.
-
 
136
	 *
121
	 * Destructeur de classe, renvoie les exceptions s'il y en a
137
	 * @param String $chemin_squelette le chemin du fichier du squelette
-
 
138
	 *
-
 
139
	 * @return string le contenu du fichier du squelette php avec les tags courts remplacés.
122
	 */
140
	 */
123
	public function __destruct() {
141
	private function traiterTagsCourts($chemin_squelette) {
124
		GestionnaireException::getExceptions();
142
		$contenu = file_get_contents($chemin_squelette);
-
 
143
		// Remplacement de tags courts par un tag long avec echo
-
 
144
		$contenu = str_replace('<?=', '<?php echo ',  $contenu);
-
 
145
		// FIXME : à quoi sert ce deuxième remplacement?
-
 
146
		$contenu = preg_replace("/;*\s*\?>/", "; ?>", $contenu);
-
 
147
		return $contenu;
125
	}
148
	}
126
}
149
}
127
?>
150
?>
128
151