* Copyright 2005-2007, Cake Software Foundation, Inc. * 1785 E. Sahara Avenue, Suite 490-204 * Las Vegas, Nevada 89104 * * Licensed under The MIT License * Redistributions of files must retain the above copyright notice. * * @filesource * @copyright Copyright 2005-2007, Cake Software Foundation, Inc. * @link http://www.cakefoundation.org/projects/info/cakephp CakePHP(tm) Project * @package cake * @subpackage cake.cake.libs * @since CakePHP(tm) v 1.2 * @version $Revision$ * @modifiedby $LastChangedBy$ * @lastmodified $Date$ * @license http://www.opensource.org/licenses/mit-license.php The MIT License */ /** * Overloadable class selector * * @package cake * @subpackage cake.cake.libs */ /** * Load the interface class based on the version of PHP. * */ class Overloadable extends Object { /** * Overload implementation. No need for implementation in PHP5. * * @access public */ function overload() { } /** * Magic method handler. * * @param string $method Method name * @param array $params Parameters to send to method * @return mixed Return value from method * @access private */ function __call($method, $params) { if(!method_exists($this, 'call__')) { trigger_error(sprintf(__('Magic method handler call__ not defined in %s', true), get_class($this)), E_USER_ERROR); } return $this->call__($method, $params); } } class Overloadable2 extends Object { /** * Overload implementation. No need for implementation in PHP5. * * @access public */ function overload() { } /** * Magic method handler. * * @param string $method Method name * @param array $params Parameters to send to method * @return mixed Return value from method * @access private */ function __call($method, $params) { if(!method_exists($this, 'call__')) { trigger_error(sprintf(__('Magic method handler call__ not defined in %s', true), get_class($this)), E_USER_ERROR); } return $this->call__($method, $params); } /** * Getter. * * @param mixed $name What to get * @param mixed $value Where to store returned value * @return boolean Success */ function __get($name) { return $this->get__($name); } /** * Setter. * * @param mixed $name What to set * @param mixed $value Value to set * @return boolean Success */ function __set($name, $value) { return $this->set__($name, $value); } } ?>