⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 errorstack.php

📁 This is the script which used on 10minutemail.com for temporary email.
💻 PHP
📖 第 1 页 / 共 3 页
字号:
     * Pop an error off of the error stack     *      * @return false|array     * @since 0.4alpha it is no longer possible to specify a specific error     * level to return - the last error pushed will be returned, instead     */    function pop()    {        $err = @array_shift($this->_errors);        if (!is_null($err)) {            @array_pop($this->_errorsByLevel[$err['level']]);            if (!count($this->_errorsByLevel[$err['level']])) {                unset($this->_errorsByLevel[$err['level']]);            }        }        return $err;    }    /**     * Pop an error off of the error stack, static method     *     * @param string package name     * @return boolean     * @since PEAR1.5.0a1     */    function staticPop($package)    {        if ($package) {            if (!isset($GLOBALS['_PEAR_ERRORSTACK_SINGLETON'][$package])) {                return false;            }            return $GLOBALS['_PEAR_ERRORSTACK_SINGLETON'][$package]->pop();        }    }    /**     * Determine whether there are any errors on the stack     * @param string|array Level name.  Use to determine if any errors     * of level (string), or levels (array) have been pushed     * @return boolean     */    function hasErrors($level = false)    {        if ($level) {            return isset($this->_errorsByLevel[$level]);        }        return count($this->_errors);    }        /**     * Retrieve all errors since last purge     *      * @param boolean set in order to empty the error stack     * @param string level name, to return only errors of a particular severity     * @return array     */    function getErrors($purge = false, $level = false)    {        if (!$purge) {            if ($level) {                if (!isset($this->_errorsByLevel[$level])) {                    return array();                } else {                    return $this->_errorsByLevel[$level];                }            } else {                return $this->_errors;            }        }        if ($level) {            $ret = $this->_errorsByLevel[$level];            foreach ($this->_errorsByLevel[$level] as $i => $unused) {                // entries are references to the $_errors array                $this->_errorsByLevel[$level][$i] = false;            }            // array_filter removes all entries === false            $this->_errors = array_filter($this->_errors);            unset($this->_errorsByLevel[$level]);            return $ret;        }        $ret = $this->_errors;        $this->_errors = array();        $this->_errorsByLevel = array();        return $ret;    }        /**     * Determine whether there are any errors on a single error stack, or on any error stack     *     * The optional parameter can be used to test the existence of any errors without the need of     * singleton instantiation     * @param string|false Package name to check for errors     * @param string Level name to check for a particular severity     * @return boolean     * @static     */    function staticHasErrors($package = false, $level = false)    {        if ($package) {            if (!isset($GLOBALS['_PEAR_ERRORSTACK_SINGLETON'][$package])) {                return false;            }            return $GLOBALS['_PEAR_ERRORSTACK_SINGLETON'][$package]->hasErrors($level);        }        foreach ($GLOBALS['_PEAR_ERRORSTACK_SINGLETON'] as $package => $obj) {            if ($obj->hasErrors($level)) {                return true;            }        }        return false;    }        /**     * Get a list of all errors since last purge, organized by package     * @since PEAR 1.4.0dev BC break! $level is now in the place $merge used to be     * @param boolean $purge Set to purge the error stack of existing errors     * @param string  $level Set to a level name in order to retrieve only errors of a particular level     * @param boolean $merge Set to return a flat array, not organized by package     * @param array   $sortfunc Function used to sort a merged array - default     *        sorts by time, and should be good for most cases     * @static     * @return array      */    function staticGetErrors($purge = false, $level = false, $merge = false,                             $sortfunc = array('PEAR_ErrorStack', '_sortErrors'))    {        $ret = array();        if (!is_callable($sortfunc)) {            $sortfunc = array('PEAR_ErrorStack', '_sortErrors');        }        foreach ($GLOBALS['_PEAR_ERRORSTACK_SINGLETON'] as $package => $obj) {            $test = $GLOBALS['_PEAR_ERRORSTACK_SINGLETON'][$package]->getErrors($purge, $level);            if ($test) {                if ($merge) {                    $ret = array_merge($ret, $test);                } else {                    $ret[$package] = $test;                }            }        }        if ($merge) {            usort($ret, $sortfunc);        }        return $ret;    }        /**     * Error sorting function, sorts by time     * @access private     */    function _sortErrors($a, $b)    {        if ($a['time'] == $b['time']) {            return 0;        }        if ($a['time'] < $b['time']) {            return 1;        }        return -1;    }    /**     * Standard file/line number/function/class context callback     *     * This function uses a backtrace generated from {@link debug_backtrace()}     * and so will not work at all in PHP < 4.3.0.  The frame should     * reference the frame that contains the source of the error.     * @return array|false either array('file' => file, 'line' => line,     *         'function' => function name, 'class' => class name) or     *         if this doesn't work, then false     * @param unused     * @param integer backtrace frame.     * @param array Results of debug_backtrace()     * @static     */    function getFileLine($code, $params, $backtrace = null)    {        if ($backtrace === null) {            return false;        }        $frame = 0;        $functionframe = 1;        if (!isset($backtrace[1])) {            $functionframe = 0;        } else {            while (isset($backtrace[$functionframe]['function']) &&                  $backtrace[$functionframe]['function'] == 'eval' &&                  isset($backtrace[$functionframe + 1])) {                $functionframe++;            }        }        if (isset($backtrace[$frame])) {            if (!isset($backtrace[$frame]['file'])) {                $frame++;            }            $funcbacktrace = $backtrace[$functionframe];            $filebacktrace = $backtrace[$frame];            $ret = array('file' => $filebacktrace['file'],                         'line' => $filebacktrace['line']);            // rearrange for eval'd code or create function errors            if (strpos($filebacktrace['file'], '(') &&             	  preg_match(';^(.*?)\((\d+)\) : (.*?)\\z;', $filebacktrace['file'],                  $matches)) {                $ret['file'] = $matches[1];                $ret['line'] = $matches[2] + 0;            }            if (isset($funcbacktrace['function']) && isset($backtrace[1])) {                if ($funcbacktrace['function'] != 'eval') {                    if ($funcbacktrace['function'] == '__lambda_func') {                        $ret['function'] = 'create_function() code';                    } else {                        $ret['function'] = $funcbacktrace['function'];                    }                }            }            if (isset($funcbacktrace['class']) && isset($backtrace[1])) {                $ret['class'] = $funcbacktrace['class'];            }            return $ret;        }        return false;    }        /**     * Standard error message generation callback     *      * This method may also be called by a custom error message generator     * to fill in template values from the params array, simply     * set the third parameter to the error message template string to use     *      * The special variable %__msg% is reserved: use it only to specify     * where a message passed in by the user should be placed in the template,     * like so:     *      * Error message: %msg% - internal error     *      * If the message passed like so:     *      * <code>     * $stack->push(ERROR_CODE, 'error', array(), 'server error 500');     * </code>     *      * The returned error message will be "Error message: server error 500 -     * internal error"     * @param PEAR_ErrorStack     * @param array     * @param string|false Pre-generated error message template     * @static     * @return string     */    function getErrorMessage(&$stack, $err, $template = false)    {        if ($template) {            $mainmsg = $template;        } else {            $mainmsg = $stack->getErrorMessageTemplate($err['code']);        }        $mainmsg = str_replace('%__msg%', $err['message'], $mainmsg);        if (is_array($err['params']) && count($err['params'])) {            foreach ($err['params'] as $name => $val) {                if (is_array($val)) {                    // @ is needed in case $val is a multi-dimensional array                    $val = @implode(', ', $val);                }                if (is_object($val)) {                    if (method_exists($val, '__toString')) {                        $val = $val->__toString();                    } else {                        PEAR_ErrorStack::staticPush('PEAR_ErrorStack', PEAR_ERRORSTACK_ERR_OBJTOSTRING,                            'warning', array('obj' => get_class($val)),                            'object %obj% passed into getErrorMessage, but has no __toString() method');                        $val = 'Object';                    }                }                $mainmsg = str_replace('%' . $name . '%', $val, $mainmsg);            }        }        return $mainmsg;    }        /**     * Standard Error Message Template generator from code     * @return string     */    function getErrorMessageTemplate($code)    {        if (!isset($this->_errorMsgs[$code])) {            return '%__msg%';        }        return $this->_errorMsgs[$code];    }        /**     * Set the Error Message Template array     *      * The array format must be:     * <pre>     * array(error code => 'message template',...)     * </pre>     *      * Error message parameters passed into {@link push()} will be used as input     * for the error message.  If the template is 'message %foo% was %bar%', and the     * parameters are array('foo' => 'one', 'bar' => 'six'), the error message returned will     * be 'message one was six'     * @return string     */    function setErrorMessageTemplate($template)    {        $this->_errorMsgs = $template;    }            /**     * emulate PEAR::raiseError()     *      * @return PEAR_Error     */    function raiseError()    {        require_once 'PEAR.php';        $args = func_get_args();        return call_user_func_array(array('PEAR', 'raiseError'), $args);    }}$stack = &PEAR_ErrorStack::singleton('PEAR_ErrorStack');$stack->pushCallback(array('PEAR_ErrorStack', '_handleError'));?>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -