mirror of
https://github.com/smarty-php/smarty.git
synced 2025-10-15 21:45:21 +02:00
Adds support for PHP8.0, dropping support for PHP7.0 and below. Backwards incompatible changes: - Dropped support for php asp tags in templates (removed from php since php7.0) - Dropped deprecated API calls that where only accessible through SmartyBC - Dropped support for {php} and {include_php} tags and embedded PHP in templates. Embedded PHP will now be passed through as is. - Removed all PHP_VERSION_ID and compare_version checks and conditional code blocks that are now no longer required - Dropped deprecated SMARTY_RESOURCE_CHAR_SET and SMARTY_RESOURCE_DATE_FORMAT constants - Dropped deprecated Smarty::muteExpectedErrors and Smarty::unmuteExpectedErrors API methods - Dropped deprecated $smarty->getVariable() method. Use $smarty->getTemplateVars() instead. - $smarty->registerResource() no longer accepts an array of callback functions See the changelog for more details. Switched CI from Travis to Github CI.
79 lines
2.3 KiB
PHP
79 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
* Smarty Internal Plugin Resource Stream
|
|
* Implements the streams as resource for Smarty template
|
|
*
|
|
* @package Smarty
|
|
* @subpackage TemplateResources
|
|
* @author Uwe Tews
|
|
* @author Rodney Rehm
|
|
*/
|
|
|
|
/**
|
|
* Smarty Internal Plugin Resource Stream
|
|
* Implements the streams as resource for Smarty template
|
|
*
|
|
* @link https://php.net/streams
|
|
* @package Smarty
|
|
* @subpackage TemplateResources
|
|
*/
|
|
class Smarty_Internal_Resource_Stream extends Smarty_Resource_Recompiled
|
|
{
|
|
/**
|
|
* populate Source Object with meta data from Resource
|
|
*
|
|
* @param Smarty_Template_Source $source source object
|
|
* @param Smarty_Internal_Template $_template template object
|
|
*
|
|
* @return void
|
|
*/
|
|
public function populate(Smarty_Template_Source $source, Smarty_Internal_Template $_template = null)
|
|
{
|
|
if (strpos($source->resource, '://') !== false) {
|
|
$source->filepath = $source->resource;
|
|
} else {
|
|
$source->filepath = str_replace(':', '://', $source->resource);
|
|
}
|
|
$source->uid = false;
|
|
$source->content = $this->getContent($source);
|
|
$source->timestamp = $source->exists = !!$source->content;
|
|
}
|
|
|
|
/**
|
|
* Load template's source from stream into current template object
|
|
*
|
|
* @param Smarty_Template_Source $source source object
|
|
*
|
|
* @return string template source
|
|
*/
|
|
public function getContent(Smarty_Template_Source $source)
|
|
{
|
|
$t = '';
|
|
// the availability of the stream has already been checked in Smarty_Resource::fetch()
|
|
$fp = fopen($source->filepath, 'r+');
|
|
if ($fp) {
|
|
while (!feof($fp) && ($current_line = fgets($fp)) !== false) {
|
|
$t .= $current_line;
|
|
}
|
|
fclose($fp);
|
|
return $t;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* modify resource_name according to resource handlers specifications
|
|
*
|
|
* @param Smarty $smarty Smarty instance
|
|
* @param string $resource_name resource_name to make unique
|
|
* @param boolean $isConfig flag for config resource
|
|
*
|
|
* @return string unique resource name
|
|
*/
|
|
public function buildUniqueResourceName(Smarty $smarty, $resource_name, $isConfig = false)
|
|
{
|
|
return get_class($this) . '#' . $resource_name;
|
|
}
|
|
}
|