mirror of
				https://github.com/smarty-php/smarty.git
				synced 2025-10-30 20:01:37 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			102 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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
 | |
| */
 | |
| 
 | |
| class Smarty_Internal_Resource_Stream extends Smarty_Internal_Base {
 | |
|     // 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';
 | |
| 
 | |
|     /**
 | |
|     * 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
 | |
|         return $_template->resource_name;
 | |
|     } 
 | |
| 
 | |
|     /**
 | |
|     * 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 = '';
 | |
|         $fp = fopen($_template->resource_name,'r+');
 | |
|         while (!feof($fp)) {
 | |
|             $_template->template_source .= fgets($fp);
 | |
|         } 
 | |
|         fclose($fp);
 | |
| 
 | |
|         return true;
 | |
|     } 
 | |
| 
 | |
|     /**
 | |
|     * Return flag that this resource uses the compiler
 | |
|     * 
 | |
|     * @return boolean true
 | |
|     */
 | |
|     public function usesCompiler()
 | |
|     { 
 | |
|         // resource string is template, needs compiler
 | |
|         return true;
 | |
|     } 
 | |
| 
 | |
|     /**
 | |
|     * Return flag that this resource is evaluated
 | |
|     * 
 | |
|     * @return boolean true
 | |
|     */
 | |
|     public function isEvaluated()
 | |
|     { 
 | |
|         // compiled template is evaluated instead of saved to disk
 | |
|         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;
 | |
|     } 
 | |
| } 
 | |
| 
 | |
| ?>
 |