summaryrefslogtreecommitdiffstats
path: root/3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php
diff options
context:
space:
mode:
Diffstat (limited to '3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php')
-rw-r--r--3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php176
1 files changed, 176 insertions, 0 deletions
diff --git a/3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php b/3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php
new file mode 100644
index 00000000000..03b53c4dad9
--- /dev/null
+++ b/3dparty/Smarty/sysplugins/smarty_internal_resource_extends.php
@@ -0,0 +1,176 @@
+<?php
+
+/**
+ * Smarty Internal Plugin Resource Extends
+ *
+ * Implements the file system as resource for Smarty which does extend a chain of template files templates
+ *
+ * @package Smarty
+ * @subpackage TemplateResources
+ * @author Uwe Tews
+ */
+
+/**
+ * Smarty Internal Plugin Resource Extends
+ */
+class Smarty_Internal_Resource_Extends {
+ public function __construct($smarty)
+ {
+ $this->smarty = $smarty;
+ $this->_rdl = preg_quote($smarty->right_delimiter);
+ $this->_ldl = preg_quote($smarty->left_delimiter);
+ }
+ // 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';
+ // properties
+ public $usesCompiler = true;
+ public $isEvaluated = false;
+ public $allFilepaths = array();
+
+ /**
+ * Return flag if template source is existing
+ *
+ * @param object $_template template object
+ * @return boolean result
+ */
+ public function isExisting($_template)
+ {
+ $_template->getTemplateFilepath();
+ foreach ($this->allFilepaths as $_filepath) {
+ if ($_filepath === false) {
+ return false;
+ }
+ }
+ return true;
+ }
+ /**
+ * Get filepath to template source
+ *
+ * @param object $_template template object
+ * @return string filepath to template source file
+ */
+ public function getTemplateFilepath($_template)
+ {
+ $sha1String = '';
+ $_files = explode('|', $_template->resource_name);
+ foreach ($_files as $_file) {
+ $_filepath = $_template->buildTemplateFilepath ($_file);
+ if ($_filepath !== false) {
+ if (is_object($_template->smarty->security_policy)) {
+ $_template->smarty->security_policy->isTrustedResourceDir($_filepath);
+ }
+ }
+ $sha1String .= $_filepath;
+ $this->allFilepaths[$_file] = $_filepath;
+ }
+ $_template->templateUid = sha1($sha1String);
+ return $_filepath;
+ }
+
+ /**
+ * Get timestamp to template source
+ *
+ * @param object $_template template object
+ * @return integer timestamp of template source file
+ */
+ public function getTemplateTimestamp($_template)
+ {
+ return filemtime($_template->getTemplateFilepath());
+ }
+
+ /**
+ * Read template source from file
+ *
+ * @param object $_template template object
+ * @return string content of template source file
+ */
+ public function getTemplateSource($_template)
+ {
+ $this->template = $_template;
+ $_files = array_reverse($this->allFilepaths);
+ $_first = reset($_files);
+ $_last = end($_files);
+ foreach ($_files as $_file => $_filepath) {
+ if ($_filepath === false) {
+ throw new SmartyException("Unable to load template 'file : {$_file}'");
+ }
+ // read template file
+ if ($_filepath != $_first) {
+ $_template->properties['file_dependency'][sha1($_filepath)] = array($_filepath, filemtime($_filepath),'file');
+ }
+ $_template->template_filepath = $_filepath;
+ $_content = file_get_contents($_filepath);
+ if ($_filepath != $_last) {
+ if (preg_match_all("!({$this->_ldl}block\s(.+?){$this->_rdl})!", $_content, $_open) !=
+ preg_match_all("!({$this->_ldl}/block{$this->_rdl})!", $_content, $_close)) {
+ $this->smarty->triggerError("unmatched {block} {/block} pairs in file '$_filepath'");
+ }
+ preg_match_all("!{$this->_ldl}block\s(.+?){$this->_rdl}|{$this->_ldl}/block{$this->_rdl}!", $_content, $_result, PREG_OFFSET_CAPTURE);
+ $_result_count = count($_result[0]);
+ $_start = 0;
+ while ($_start < $_result_count) {
+ $_end = 0;
+ $_level = 1;
+ while ($_level != 0) {
+ $_end++;
+ if (!strpos($_result[0][$_start + $_end][0], '/')) {
+ $_level++;
+ } else {
+ $_level--;
+ }
+ }
+ $_block_content = str_replace($this->smarty->left_delimiter . '$smarty.block.parent' . $this->smarty->right_delimiter, '%%%%SMARTY_PARENT%%%%',
+ substr($_content, $_result[0][$_start][1] + strlen($_result[0][$_start][0]), $_result[0][$_start + $_end][1] - $_result[0][$_start][1] - + strlen($_result[0][$_start][0])));
+ Smarty_Internal_Compile_Block::saveBlockData($_block_content, $_result[0][$_start][0], $_template, $_filepath);
+ $_start = $_start + $_end + 1;
+ }
+ } else {
+ $_template->template_source = $_content;
+ return true;
+ }
+ }
+ }
+
+
+ /**
+ * Get filepath to compiled template
+ *
+ * @param object $_template template object
+ * @return string return path to compiled template
+ */
+ public function getCompiledFilepath($_template)
+ {
+ $_compile_id = isset($_template->compile_id) ? preg_replace('![^\w\|]+!', '_', $_template->compile_id) : null;
+ $_files = explode('|', $_template->resource_name);
+ // calculate Uid if not already done
+ if ($_template->templateUid == '') {
+ $_template->getTemplateFilepath();
+ }
+ $_filepath = $_template->templateUid;
+ // if use_sub_dirs, break file into directories
+ if ($_template->smarty->use_sub_dirs) {
+ $_filepath = substr($_filepath, 0, 2) . DS
+ . substr($_filepath, 2, 2) . DS
+ . substr($_filepath, 4, 2) . DS
+ . $_filepath;
+ }
+ $_compile_dir_sep = $_template->smarty->use_sub_dirs ? DS : '^';
+ if (isset($_compile_id)) {
+ $_filepath = $_compile_id . $_compile_dir_sep . $_filepath;
+ }
+ if ($_template->caching) {
+ $_cache = '.cache';
+ } else {
+ $_cache = '';
+ }
+ $_compile_dir = $_template->smarty->compile_dir;
+ if (substr($_compile_dir, -1) != DS) {
+ $_compile_dir .= DS;
+ }
+ return $_compile_dir . $_filepath . '.' . $_template->resource_type . '.' . basename($_files[count($_files)-1]) . $_cache . '.php';
+ }
+}
+
+?> \ No newline at end of file