2 /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
4 // +----------------------------------------------------------------------+
5 // | Akelos Framework - http://www.akelos.org |
6 // +----------------------------------------------------------------------+
7 // | Copyright (c) 2002-2006, Akelos Media, S.L. & Bermi Ferrer Martinez |
8 // | Released under the GNU Lesser General Public License, see LICENSE.txt|
9 // +----------------------------------------------------------------------+
12 * @package ActiveSupport
13 * @subpackage Compatibility
14 * @author Bermi Ferrer <bermi a.t akelos c.om>
15 * @copyright Copyright (c) 2002-2006, Akelos Media, S.L. http://www.akelos.org
16 * @license GNU Lesser General Public License <http://www.gnu.org/copyleft/lesser.html>
19 if(!class_exists('AkObject')){
22 * Allows for __construct and __destruct to be used in PHP4.
24 * A hack to support __construct() on PHP 4
25 * Hint: descendant classes have no PHP4 class_name()
26 * constructors, so this one gets called first and calls the
27 * top-layer __construct() which (if present) should call
28 * parent::__construct()
30 * @author Bermi Ferrer <bermi a.t akelos c.om>
31 * @copyright Copyright (c) 2002-2005, Akelos Media, S.L. http://www.akelos.org
32 * @license GNU Lesser General Public License <http://www.gnu.org/copyleft/lesser.html>
39 // ------ CLASS METHODS ------ //
44 // ---- Public methods ---- //
50 * A hack to support __construct() on PHP 4
52 * Hint: descendant classes have no PHP4 class_name()
53 * constructors, so this one gets called first and calls the
54 * top-layer __construct() which (if present) should call
55 * parent::__construct()
62 static $_callback_called;
63 Ak
::profile('Instantiating '.get_class($this));
64 $args = func_get_args();
65 // register_shutdown_function(array(&$this, '__destruct'));
66 ____ak_shutdown_function(&$this);
67 call_user_func_array(array(&$this, '__construct'), $args);
69 if(empty($_callback_called)){
70 $_callback_called = true;
71 register_shutdown_function('____ak_shutdown_function');
79 * Object-to-string conversion
81 * Each class can override it as necessary
84 * @return string in this case returns this class name
88 return get_class($this);
93 return $this->toString();
99 // ---- Protected methods ---- //
105 * Class constructor, overriden in descendant classes
110 function __construct()
119 * Class destructor, overriden in descendant classes
124 function __destruct()
135 * Clone class (Zend Engine 2 compatibility trick)
144 function log($message, $type = '', $identifyer = '')
146 require_once 'Log.php';
147 $ident = empty($ident) ?
'main' : $ident;
149 $log = Log
::singleton('file', AK_LOGS_DIR
.DS
.$ident.'.log',$ident);
150 $log->log($type, $message);
156 function ____ak_shutdown_function($details = false)
158 static $___registered_objects;
160 Ak
::profile('Calling shutdown destructors');
161 foreach (array_keys($___registered_objects) as $k){
162 if(!empty($___registered_objects[$k]) && is_object($___registered_objects[$k]) && method_exists($___registered_objects[$k],'__destruct')){
163 Ak
::profile('Calling destructor for '.get_class($___registered_objects[$k]));
164 $___registered_objects[$k]->__destruct();
168 $___registered_objects[] =& $details;