Subversion Repositories Applications.framework

Rev

Rev 146 | Rev 152 | Go to most recent revision | Show entire file | Regard 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/
Line 75... Line 74...
75
		return $sortie;
74
		return $sortie;
76
	}
75
	}
Line 77... Line 76...
77
 
76
	
78
	/**
77
	/**
79
	 * 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
78
	 * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données,
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
	 */
-
 
86
	final protected function getVue($nom_squelette, $donnees = array()) {
88
	final protected function chargerVue($nom_squelette,$donnees) {
87
		$sortie = false;
-
 
88
		$chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
Line 89... Line -...
89
		$chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
-
 
90
 
-
 
91
		if (!file_exists($chemin_squelette)) {
-
 
92
			return false ;
-
 
93
		}
-
 
94
 
-
 
95
		$donnees['base_url'] = $this->registre->get('base_url_application');
89
		if (file_exists($chemin_squelette)) {
96
 
90
	
97
		// on extrait les variables du tableau de données
-
 
98
		extract($donnees);
91
			// Extraction des variables du tableau de données
99
 
92
			extract($donnees);
100
		// et on enclenche la bufferisation de sortie
-
 
101
		ob_start();
93
			// Démarage de la bufferisation de sortie
102
 
94
			ob_start();
103
		// si les tags courts sont désactivés
95
			// si les tags courts sont désactivés
104
		if ((bool) @ini_get('short_open_tag') === false) {
96
			if ((bool) @ini_get('short_open_tag') === false) {
105
			// on remplace les tags par la syntaxe classique avec echo
97
				// Remplacement des tags courts par la syntaxe classique avec echo
106
			echo eval('?>'.preg_replace("/;*\s*\?>/", "; ?>", str_replace('<?=', '<?php echo ', file_get_contents($chemin_squelette))));
98
				echo eval('?>'.$this->traiterTagsCourts($chemin_squelette));
107
		} else {
99
			} else {
108
			// sinon, on se contente d'inclure le squelette
100
				// sinon, on se contente d'inclure le squelette
109
			include $chemin_squelette;
-
 
110
		}
101
				include $chemin_squelette;
111
 
102
			}
-
 
103
			// Récupèration du contenu du buffer
112
		// on récupère le buffer et on le vide
104
			$sortie = ob_get_contents();
-
 
105
			// Suppression du buffer
Line 113... Line 106...
113
		$tampon = ob_get_contents();
106
			@ob_end_clean();
114
		@ob_end_clean();
107
		}
115
 
108
		
Line 116... Line 109...
116
		// enfin on renvoie le contenu
109
		// Retour du contenu
-
 
110
		return $sortie;
-
 
111
	}
-
 
112
	
-
 
113
	/**
-
 
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 
-
 
116
	 * contenant les deux combinés.
117
		$this->$nom_squelette = $tampon;
117
	 *
-
 
118
	 * @param String $nom_squelette le nom du squelette
-
 
119
	 * @param Array  $donnees	   un tableau associatif contenant les variables a injecter dans la vue
-
 
120
	 *
-
 
121
	 * @return boolean false si la vue n'existe pas, sinon true.
-
 
122
	 */
-
 
123
	final protected function chargerVue($nom_squelette, $donnees = array()) {
-
 
124
		$sortie = false;
-
 
125
		$rendu = $this->getVue($nom_squelette, $donnees);
-
 
126
		if ($rendu !== false) {
-
 
127
			// Création d'une variable de classe contenant le rendu
-
 
128
			$this->$nom_squelette = $rendu;
-
 
129
			$sortie = true;
-
 
130
		}
-
 
131
		return $sortie;
-
 
132
	}
-
 
133
	
-
 
134
	/**
-
 
135
	 * Fonction chargeant le contenu du squelette et remplaçant les tags court php (<?= ...) par un tag long avec echo.
118
	}
136
	 *
119
 
137
	 * @param String $chemin_squelette le chemin du fichier du squelette
120
	/**
138
	 *
-
 
139
	 * @return string le contenu du fichier du squelette php avec les tags courts remplacés.
-
 
140
	 */
-
 
141
	private function traiterTagsCourts($chemin_squelette) {
-
 
142
		$contenu = file_get_contents($chemin_squelette);
-
 
143
		// Remplacement de tags courts par un tag long avec echo
121
	 * Destructeur de classe, renvoie les exceptions s'il y en a
144
		$contenu = str_replace('<?=', '<?php echo ',  $contenu);
122
	 */
145
		// FIXME : à quoi sert ce deuxième remplacement?
123
	public function __destruct() {
146
		$contenu = preg_replace("/;*\s*\?>/", "; ?>", $contenu);
124
		GestionnaireException::getExceptions();
147
		return $contenu;