2007-08-16 06:32:49 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2009-03-31 19:32:51 +00:00
|
|
|
* Add extension that can be added to an object with {@link Object::add_extension()}.
|
|
|
|
* For {@link DataObject} extensions, use {@link DataObjectDecorator}.
|
|
|
|
* Each extension instance has an "owner" instance, accessible through
|
|
|
|
* {@link getOwner()}.
|
|
|
|
* Every object instance gets its own set of extension instances,
|
|
|
|
* meaning you can set parameters specific to the "owner instance"
|
|
|
|
* in new Extension instances.
|
2008-02-25 02:10:37 +00:00
|
|
|
*
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage core
|
2007-08-16 06:32:49 +00:00
|
|
|
*/
|
|
|
|
abstract class Extension extends Object {
|
2008-03-11 01:30:19 +00:00
|
|
|
/**
|
|
|
|
* This is used by extensions designed to be applied to controllers.
|
|
|
|
* It works the same way as {@link Controller::$allowed_actions}.
|
|
|
|
*/
|
|
|
|
public static $allowed_actions = null;
|
|
|
|
|
2007-08-16 06:32:49 +00:00
|
|
|
/**
|
|
|
|
* The DataObject that owns this decorator.
|
|
|
|
* @var DataObject
|
|
|
|
*/
|
|
|
|
protected $owner;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the owner of this decorator.
|
|
|
|
* @param DataObject $owner
|
|
|
|
*/
|
|
|
|
function setOwner(Object $owner) {
|
|
|
|
$this->owner = $owner;
|
|
|
|
}
|
2009-01-10 11:35:50 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the owner of this decorator
|
|
|
|
*
|
|
|
|
* @return Object
|
|
|
|
*/
|
|
|
|
public function getOwner() {
|
|
|
|
return $this->owner;
|
|
|
|
}
|
2009-03-31 19:32:51 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper method to strip eval'ed arguments from a string
|
|
|
|
* thats passed to {@link DataObject::$extensions} or
|
|
|
|
* {@link Object::add_extension()}.
|
|
|
|
*
|
|
|
|
* @param string $extensionStr E.g. "Versioned('Stage','Live')"
|
|
|
|
* @return string Extension classname, e.g. "Versioned"
|
|
|
|
*/
|
|
|
|
public static function get_classname_without_arguments($extensionStr) {
|
|
|
|
return (($p = strpos($extensionStr, '(')) !== false) ? substr($extensionStr, 0, $p) : $extensionStr;
|
|
|
|
}
|
|
|
|
|
2007-08-16 06:32:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
?>
|