2009-06-17 10:25:53 +00:00

195 lines
4.8 KiB
PHP

<?php
/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.org>.
*/
/**
* Base abstract class for defining templates which are the base of all behaviors that can be attached
* to your Doctrine models
*
* @package Doctrine
* @subpackage Template
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @link www.phpdoctrine.org
* @since 1.0
* @version $Revision$
* @author Konsta Vesterinen <kvesteri@cc.hut.fi>
*/
abstract class Doctrine_Template extends Doctrine_Record_Abstract
{
/**
* @var Doctrine_Record $_invoker the record that invoked the last delegated call
*/
protected $_invoker;
/**
* @var Doctrine_Record_Generator $_plugin
*/
protected $_plugin;
/**
* @var array $_options Template options
*/
protected $_options = array();
/**
* __construct
*
* @param string $array
* @return void
*/
public function __construct(array $options = array())
{
$this->_options = Doctrine_Lib::arrayDeepMerge($this->_options, $options);
}
/**
* Set the table object that this Template belongs to
*
* @var Doctrine_Table $table the table object this Template belongs to
*/
public function setTable(Doctrine_Table $table)
{
$this->_table = $table;
}
/**
* returns the associated table object
*
* @return Doctrine_Table the associated table object
*/
public function getTable()
{
return $this->_table;
}
/**
* sets the last used invoker
*
* @param Doctrine_Record $invoker the record that invoked the last delegated call
* @return Doctrine_Template this object
*/
public function setInvoker(Doctrine_Record_Abstract $invoker)
{
$this->_invoker = $invoker;
}
/**
* returns the last used invoker
*
* @return Doctrine_Record the record that invoked the last delegated call
*/
public function getInvoker()
{
return $this->_invoker;
}
/**
* Adds a plugin as a child to this plugin
*
* @param Doctrine_Template $template
* @return Doctrine_Template. Chainable.
*/
public function addChild(Doctrine_Template $template)
{
$this->_plugin->addChild($template);
return $this;
}
/**
* Get plugin instance
*
* @return void
*/
public function getPlugin()
{
return $this->_plugin;
}
/**
* getOptions
* returns all options of this template and the associated values
*
* @return array all options and their values
*/
public function getOptions()
{
return $this->_options;
}
/**
* getOption
* returns the value of given option
*
* @param string $name the name of the option
* @param mixed $default default value if option is not found
* @return mixed the value of given option
*/
public function getOption($name, $default = null)
{
if (isset($this->_options[$name])) {
return $this->_options[$name];
}
return $default;
}
/**
* get
*
* @param mixed $name
* @return void
*/
public function get($name)
{
throw new Doctrine_Exception("Templates doesn't support accessors.");
}
/**
* set
*
* @param mixed $name
* @param mixed $value
* @return void
*/
public function set($name, $value)
{
throw new Doctrine_Exception("Templates doesn't support accessors.");
}
/**
* Blank method for template setup
*
* @return void
*/
public function setUp()
{
}
/**
* Blank method for template table definition
*
* @return void
*/
public function setTableDefinition()
{
}
}