mirror of
https://github.com/smarty-php/smarty.git
synced 2025-10-20 16:05:20 +02: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;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
?>
|