| 
<?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.");
 }
 }
 
 }
 
 |