|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Smarty Internal Plugin
|
|
|
|
*
|
|
|
|
* @package Smarty
|
|
|
|
* @subpackage TemplateResources
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Smarty Resource Data Object
|
|
|
|
*
|
|
|
|
* Meta Data Container for Config Files
|
|
|
|
*
|
|
|
|
* @package Smarty
|
|
|
|
* @subpackage TemplateResources
|
|
|
|
* @author Rodney Rehm
|
|
|
|
*
|
|
|
|
* @property string $content
|
|
|
|
* @property int $timestamp
|
|
|
|
* @property bool $exists
|
|
|
|
*/
|
|
|
|
class Smarty_Config_Source extends Smarty_Template_Source
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* create Config Object container
|
|
|
|
*
|
|
|
|
* @param Smarty_Resource $handler Resource Handler this source object communicates with
|
|
|
|
* @param Smarty $smarty Smarty instance this source object belongs to
|
|
|
|
* @param string $resource full config_resource
|
|
|
|
* @param string $type type of resource
|
|
|
|
* @param string $name resource name
|
|
|
|
* @param string $unique_resource unqiue resource name
|
|
|
|
*/
|
|
|
|
public function __construct(Smarty_Resource $handler, Smarty $smarty, $resource, $type, $name, $unique_resource)
|
|
|
|
{
|
|
|
|
$this->handler = $handler; // Note: prone to circular references
|
|
|
|
|
|
|
|
// Note: these may be ->config_compiler_class etc in the future
|
|
|
|
//$this->config_compiler_class = $handler->config_compiler_class;
|
|
|
|
//$this->config_lexer_class = $handler->config_lexer_class;
|
|
|
|
//$this->config_parser_class = $handler->config_parser_class;
|
|
|
|
|
|
|
|
$this->smarty = $smarty;
|
|
|
|
$this->resource = $resource;
|
|
|
|
$this->type = $type;
|
|
|
|
$this->name = $name;
|
|
|
|
$this->unique_resource = $unique_resource;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* <<magic>> Generic setter.
|
|
|
|
*
|
|
|
|
* @param string $property_name valid: content, timestamp, exists
|
|
|
|
* @param mixed $value newly assigned value (not check for correct type)
|
|
|
|
* @throws SmartyException when the given property name is not valid
|
|
|
|
*/
|
|
|
|
public function __set($property_name, $value)
|
|
|
|
{
|
|
|
|
switch ($property_name) {
|
|
|
|
case 'content':
|
|
|
|
case 'timestamp':
|
|
|
|
case 'exists':
|
|
|
|
$this->$property_name = $value;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
throw new SmartyException("invalid config property '$property_name'.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* <<magic>> Generic getter.
|
|
|
|
*
|
|
|
|
* @param string $property_name valid: content, timestamp, exists
|
|
|
|
* @throws SmartyException when the given property name is not valid
|
|
|
|
*/
|
|
|
|
public function __get($property_name)
|
|
|
|
{
|
|
|
|
switch ($property_name) {
|
|
|
|
case 'timestamp':
|
|
|
|
case 'exists':
|
|
|
|
$this->handler->populateTimestamp($this);
|
|
|
|
|
|
|
|
return $this->$property_name;
|
|
|
|
|
|
|
|
case 'content':
|
|
|
|
return $this->content = $this->handler->getContent($this);
|
|
|
|
|
|
|
|
default:
|
|
|
|
throw new SmartyException("config property '$property_name' does not exist.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|