| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  | * Smarty Internal Plugin Resource Stream | 
					
						
							|  |  |  | *  | 
					
						
							|  |  |  | * Implements the streams as resource for Smarty template | 
					
						
							|  |  |  | *  | 
					
						
							|  |  |  | * @package Smarty | 
					
						
							|  |  |  | * @subpackage TemplateResources | 
					
						
							|  |  |  | * @author Uwe Tews  | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  | * Smarty Internal Plugin Resource Stream | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-08 17:28:23 +00:00
										 |  |  | class Smarty_Internal_Resource_Stream { | 
					
						
							|  |  |  |     public function __construct($smarty) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->smarty = $smarty; | 
					
						
							|  |  |  |     }  | 
					
						
							| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  |     // classes used for compiling Smarty templates from file resource
 | 
					
						
							|  |  |  |     public $compiler_class = 'Smarty_Internal_SmartyTemplateCompiler'; | 
					
						
							|  |  |  |     public $template_lexer_class = 'Smarty_Internal_Templatelexer'; | 
					
						
							|  |  |  |     public $template_parser_class = 'Smarty_Internal_Templateparser'; | 
					
						
							| 
									
										
										
										
											2009-12-27 15:06:49 +00:00
										 |  |  |     // properties
 | 
					
						
							|  |  |  |     public $usesCompiler = true; | 
					
						
							|  |  |  |     public $isEvaluated = true; | 
					
						
							| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-30 18:28:50 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Return flag if template source is existing | 
					
						
							|  |  |  |     *  | 
					
						
							|  |  |  |     * @return boolean true | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function isExisting($template) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-09-30 22:03:41 +00:00
										 |  |  |         if ($template->getTemplateSource() == '') { | 
					
						
							| 
									
										
										
										
											2009-09-30 18:28:50 +00:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         }  | 
					
						
							|  |  |  |     }  | 
					
						
							| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |     * Get filepath to template source | 
					
						
							|  |  |  |     *  | 
					
						
							|  |  |  |     * @param object $_template template object | 
					
						
							|  |  |  |     * @return string return 'string' as template source is not a file | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function getTemplateFilepath($_template) | 
					
						
							|  |  |  |     {  | 
					
						
							|  |  |  |         // no filepath for strings
 | 
					
						
							|  |  |  |         // return resource name for compiler error messages
 | 
					
						
							| 
									
										
										
										
											2009-10-04 18:12:30 +00:00
										 |  |  |         return str_replace(':', '://', $_template->template_resource); | 
					
						
							| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  |     }  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |     * Get timestamp to template source | 
					
						
							|  |  |  |     *  | 
					
						
							|  |  |  |     * @param object $_template template object | 
					
						
							|  |  |  |     * @return boolean false as string resources have no timestamp | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function getTemplateTimestamp($_template) | 
					
						
							|  |  |  |     {  | 
					
						
							|  |  |  |         // strings must always be compiled and have no timestamp
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     }  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |     * Retuen template source from resource name | 
					
						
							|  |  |  |     *  | 
					
						
							|  |  |  |     * @param object $_template template object | 
					
						
							|  |  |  |     * @return string content of template source | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function getTemplateSource($_template) | 
					
						
							|  |  |  |     {  | 
					
						
							|  |  |  |         // return template string
 | 
					
						
							|  |  |  |         $_template->template_source = ''; | 
					
						
							| 
									
										
										
										
											2009-10-04 18:12:30 +00:00
										 |  |  |         $fp = fopen(str_replace(':', '://', $_template->template_resource),'r+'); | 
					
						
							| 
									
										
										
										
											2009-04-18 14:46:29 +00:00
										 |  |  |         while (!feof($fp)) { | 
					
						
							|  |  |  |             $_template->template_source .= fgets($fp); | 
					
						
							|  |  |  |         }  | 
					
						
							|  |  |  |         fclose($fp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     }  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |     * Get filepath to compiled template | 
					
						
							|  |  |  |     *  | 
					
						
							|  |  |  |     * @param object $_template template object | 
					
						
							|  |  |  |     * @return boolean return false as compiled template is not stored | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     public function getCompiledFilepath($_template) | 
					
						
							|  |  |  |     {  | 
					
						
							|  |  |  |         // no filepath for strings
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     }  | 
					
						
							|  |  |  | }  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 |