_kjwobject_id = ++$kjwobject_id; $this->_kjwobject_last_error = null; if (KJW_DEBUG) $this->trace("Creating " . $this->id() . ", total objects now = $kjw_object_count.", 'MEMORY'); } /** * Destructor performing cleanup. * Don't rely on this being called ever. The user must call it by hand. */ function destroy() { global $kjw_object_count; --$kjw_object_count; if (KJW_DEBUG) $this->trace("Destroying " . $this->id() . ", total objects left = $kjw_object_count.", 'MEMORY'); } /** * Returns a string with a unique object id. * * @return The string "KjwObject(#N)" where N is a number. */ function id() { return 'KjwObject(#' . $this->_kjwobject_id . ')::' . get_class($this); } /** * Set an error. XXX do we use this? * * @param $errorMessage The error message to be stored. */ function setError($errorMessage) { assert('is_string($errorMessage)'); $this->trace("(transient) $errorMessage", 'ERROR'); if ($this->_kjwobject_last_error === null) $this->_kjwobject_last_error = $errorMessage; } /** * Get last error. * * @return The last stored error as string, or null if there was no error. */ function getError() { return $this->_kjwobject_last_error; } /** * Die with an "Not implemented!" message. With this hack we can define * abstract classes in PHP4. */ function notImplemented() { $this->croak('Library Component Error', 'Abstract method not implemented!'); } /** * Print a message to the resource pointed to by KJW_STDLOG. * * @param $msg The message to print. * @param $level The message importance level (e.g. WARNING). */ function trace($msg, $level = 'DEBUG') { kjw_trace($msg, $level, $this->id()); } /** * See kjw_croak(). */ function croak($shortMsg, $detailedMsg, $backtraceShift = 1) { kjw_croak($this->id(), $shortMsg, $detailedMsg, $backtraceShift); } } ?>