X-Git-Url: http://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FWikiError.php;h=a634dff646b570f26da148f0590527f3d0f0f8b8;hb=6cc931502f07fd2d1fc6dcf9d850a2c462eda7bd;hp=f693003a5ffa9898297f1af2ab49980796d027ed;hpb=157861bc31bdf7058328cee47ec296cb693c6a55;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/WikiError.php b/includes/WikiError.php index f693003a5f..a634dff646 100644 --- a/includes/WikiError.php +++ b/includes/WikiError.php @@ -1,47 +1,51 @@ + * + * Copyright © 2005 Brion Vibber * http://www.mediawiki.org/ - * + * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. - * + * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. - * + * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * http://www.gnu.org/copyleft/gpl.html * - * @package MediaWiki + * @file */ /** * Since PHP4 doesn't have exceptions, here's some error objects * loosely modeled on the standard PEAR_Error model... - * @package MediaWiki + * @ingroup Exception */ class WikiError { /** - * @param string $message + * @param $message string + * + * @deprecated since 1.17 */ - function WikiError( $message ) { + function __construct( $message ) { + wfDeprecated( __METHOD__ ); $this->mMessage = $message; } - + /** * @return string Plaintext error message to display */ function getMessage() { return $this->mMessage; } - + /** * In following PEAR_Error model this could be formatted differently, * but so far it's not. @@ -50,55 +54,101 @@ class WikiError { function toString() { return $this->getMessage(); } - + /** * Returns true if the given object is a WikiError-descended * error object, false otherwise. * - * @param mixed $object + * @param $object mixed * @return bool - * @static + * + * @deprecated since 1.17 */ - function isError( &$object ) { - return is_a( $object, 'WikiError' ); + public static function isError( $object ) { + wfDeprecated( __METHOD__ ); + if ( $object instanceof WikiError ) { + return true; + } elseif ( $object instanceof Status ) { + return !$object->isOK(); + } else { + return false; + } } } /** * Localized error message object - * @package MediaWiki + * @ingroup Exception */ class WikiErrorMsg extends WikiError { /** - * @param string $message Wiki message name + * @param $message String: wiki message name * @param ... parameters to pass to wfMsg() + * + * @deprecated since 1.17 */ - function WikiErrorMsg( $message/*, ... */ ) { + function __construct( $message/*, ... */ ) { + wfDeprecated( __METHOD__ ); $args = func_get_args(); array_shift( $args ); $this->mMessage = wfMsgReal( $message, $args, true ); + $this->mMsgKey = $message; + $this->mMsgArgs = $args; + } + + function getMessageKey() { + return $this->mMsgKey; + } + + function getMessageArgs() { + return $this->mMsgArgs; } } /** - * @package MediaWiki - * @todo document + * Error class designed to handle errors involved with + * XML parsing + * @ingroup Exception */ class WikiXmlError extends WikiError { /** - * @param resource $parser - * @param string $message + * @param $parser resource + * @param $message string + * @param $context + * @param $offset Int + * + * @deprecated since 1.17 */ - function WikiXmlError( $parser, $message = '' ) { + function __construct( $parser, $message = 'XML parsing error', $context = null, $offset = 0 ) { + wfDeprecated( __METHOD__ ); $this->mXmlError = xml_get_error_code( $parser ); + $this->mColumn = xml_get_current_column_number( $parser ); + $this->mLine = xml_get_current_line_number( $parser ); + $this->mByte = xml_get_current_byte_index( $parser ); + $this->mContext = $this->_extractContext( $context, $offset ); $this->mMessage = $message; xml_parser_free( $parser ); + wfDebug( "WikiXmlError: " . $this->getMessage() . "\n" ); } - /** @return string */ + /** @return string */ function getMessage() { - return $this->mMessage . ': ' . xml_error_string( $this->mXmlError ); + // '$1 at line $2, col $3 (byte $4): $5', + return wfMsgHtml( 'xml-error-string', + $this->mMessage, + $this->mLine, + $this->mColumn, + $this->mByte . $this->mContext, + xml_error_string( $this->mXmlError ) ); } -} -?> + function _extractContext( $context, $offset ) { + if( is_null( $context ) ) { + return null; + } else { + // Hopefully integer overflow will be handled transparently here + $inlineOffset = $this->mByte - $offset; + return '; "' . substr( $context, $inlineOffset, 16 ) . '"'; + } + } +}