зеркало из https://github.com/mozilla/pjs.git
implement exception constants defined in DOM level 3
b=245476, patch by jonathan.watt@strath.ac.uk, r=peterv, sr=jst remove redundant declarations and correct comment b=251824, patch by jonathan.watt@strath.ac.uk, r+sr=peterv
This commit is contained in:
Родитель
6597fbb3d4
Коммит
8ad12148c3
|
@ -40,15 +40,15 @@
|
||||||
#include "domstubs.idl"
|
#include "domstubs.idl"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In general, DOM methods return specific error values in ordinary
|
* In general, DOM methods return specific error values in ordinary
|
||||||
* processing situations, such as out-of-bound errors.
|
* processing situations, such as out-of-bound errors.
|
||||||
* However, DOM operations can raise exceptions in "exceptional"
|
* However, DOM operations can raise exceptions in "exceptional"
|
||||||
* circumstances, i.e., when an operation is impossible to perform
|
* circumstances, i.e., when an operation is impossible to perform
|
||||||
* (either for logical reasons, because data is lost, or because the
|
* (either for logical reasons, because data is lost, or because the
|
||||||
* implementation has become unstable)
|
* implementation has become unstable)
|
||||||
*
|
*
|
||||||
* For more information on this interface please see
|
* For more information on this interface please see
|
||||||
* http://www.w3.org/TR/DOM-Level-2-Core/
|
* http://www.w3.org/TR/DOM-Level-3-Core/
|
||||||
*
|
*
|
||||||
* @status FROZEN
|
* @status FROZEN
|
||||||
*/
|
*/
|
||||||
|
@ -76,6 +76,10 @@ interface nsIDOMDOMException : nsISupports
|
||||||
const unsigned short NAMESPACE_ERR = 14;
|
const unsigned short NAMESPACE_ERR = 14;
|
||||||
// Introduced in DOM Level 2:
|
// Introduced in DOM Level 2:
|
||||||
const unsigned short INVALID_ACCESS_ERR = 15;
|
const unsigned short INVALID_ACCESS_ERR = 15;
|
||||||
|
// Introduced in DOM Level 3:
|
||||||
|
const unsigned short VALIDATION_ERR = 16;
|
||||||
|
// Introduced in DOM Level 3:
|
||||||
|
const unsigned short TYPE_MISMATCH_ERR = 17;
|
||||||
|
|
||||||
readonly attribute unsigned long code;
|
readonly attribute unsigned long code;
|
||||||
};
|
};
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
#include "nsError.h"
|
#include "nsError.h"
|
||||||
|
|
||||||
// XXX If you add a new error code, also add an error string to
|
// XXX If you add a new error code, also add an error string to
|
||||||
// dom/base/src/domerr.msg
|
// dom/src/base/domerr.msg
|
||||||
|
|
||||||
/* DOM error codes from http://www.w3.org/TR/REC-DOM-Level-1/ */
|
/* DOM error codes from http://www.w3.org/TR/REC-DOM-Level-1/ */
|
||||||
|
|
||||||
|
@ -69,6 +69,11 @@
|
||||||
#define NS_ERROR_DOM_RANGE_BAD_BOUNDARYPOINTS_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM_RANGE, 1)
|
#define NS_ERROR_DOM_RANGE_BAD_BOUNDARYPOINTS_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM_RANGE, 1)
|
||||||
#define NS_ERROR_DOM_RANGE_INVALID_NODE_TYPE_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM_RANGE, 2)
|
#define NS_ERROR_DOM_RANGE_INVALID_NODE_TYPE_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM_RANGE, 2)
|
||||||
|
|
||||||
|
/* DOM error codes from http://www.w3.org/TR/DOM-Level-3/ */
|
||||||
|
|
||||||
|
#define NS_ERROR_DOM_VALIDATION_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM,16)
|
||||||
|
#define NS_ERROR_DOM_TYPE_MISMATCH_ERR NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_DOM,17)
|
||||||
|
|
||||||
|
|
||||||
/* DOM error codes defined by us */
|
/* DOM error codes defined by us */
|
||||||
|
|
||||||
|
|
|
@ -100,9 +100,6 @@ NS_INTERFACE_MAP_END \
|
||||||
NS_DEFINE_CID(kBaseDOMException_CID_##domname, NS_BASE_DOM_EXCEPTION_CID); \
|
NS_DEFINE_CID(kBaseDOMException_CID_##domname, NS_BASE_DOM_EXCEPTION_CID); \
|
||||||
\
|
\
|
||||||
nsresult \
|
nsresult \
|
||||||
NS_New##domname(nsresult aNSResult, nsIException* aDefaultException, \
|
|
||||||
nsIException** aException); \
|
|
||||||
nsresult \
|
|
||||||
NS_New##domname(nsresult aNSResult, nsIException* aDefaultException, \
|
NS_New##domname(nsresult aNSResult, nsIException* aDefaultException, \
|
||||||
nsIException** aException) \
|
nsIException** aException) \
|
||||||
{ \
|
{ \
|
||||||
|
|
|
@ -64,6 +64,11 @@ DOM_MSG_DEF(NS_ERROR_DOM_SYNTAX_ERR, "An invalid or illegal string was specified
|
||||||
DOM_MSG_DEF(NS_ERROR_DOM_RANGE_BAD_BOUNDARYPOINTS_ERR, "The boundary-points of a range does not meet specific requirements.")
|
DOM_MSG_DEF(NS_ERROR_DOM_RANGE_BAD_BOUNDARYPOINTS_ERR, "The boundary-points of a range does not meet specific requirements.")
|
||||||
DOM_MSG_DEF(NS_ERROR_DOM_RANGE_INVALID_NODE_TYPE_ERR, "The container of an boundary-point of a range is being set to either a node of an invalid type or a node with an ancestor of an invalid type.")
|
DOM_MSG_DEF(NS_ERROR_DOM_RANGE_INVALID_NODE_TYPE_ERR, "The container of an boundary-point of a range is being set to either a node of an invalid type or a node with an ancestor of an invalid type.")
|
||||||
|
|
||||||
|
/* DOM error codes from http://www.w3.org/TR/DOM-Level-3/ */
|
||||||
|
|
||||||
|
DOM_MSG_DEF(NS_ERROR_DOM_VALIDATION_ERR, "A call to a method would make the Node invalid with respect to \"partial validity\", so the operation was not done")
|
||||||
|
DOM_MSG_DEF(NS_ERROR_DOM_TYPE_MISMATCH_ERR, "The type of an object is incompatible with the expected type of the parameter associated to the object")
|
||||||
|
|
||||||
/* DOM error codes defined by us */
|
/* DOM error codes defined by us */
|
||||||
|
|
||||||
/* XXX string should be specified by norris */
|
/* XXX string should be specified by norris */
|
||||||
|
|
|
@ -1,116 +0,0 @@
|
||||||
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
||||||
/* ***** BEGIN LICENSE BLOCK *****
|
|
||||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the Mozilla Public License Version
|
|
||||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
* http://www.mozilla.org/MPL/
|
|
||||||
*
|
|
||||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
||||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
||||||
* for the specific language governing rights and limitations under the
|
|
||||||
* License.
|
|
||||||
*
|
|
||||||
* The Original Code is TransforMiiX XSLT processor code.
|
|
||||||
*
|
|
||||||
* The Initial Developer of the Original Code is
|
|
||||||
* Netscape Communications Corporation.
|
|
||||||
* Portions created by the Initial Developer are Copyright (C) 2001
|
|
||||||
* the Initial Developer. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Contributor(s):
|
|
||||||
* Peter Van der Beken <peterv@propagandism.org>
|
|
||||||
*
|
|
||||||
* Alternatively, the contents of this file may be used under the terms of
|
|
||||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
||||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
||||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
||||||
* of those above. If you wish to allow use of your version of this file only
|
|
||||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
||||||
* use your version of this file under the terms of the MPL, indicate your
|
|
||||||
* decision by deleting the provisions above and replace them with the notice
|
|
||||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
||||||
* the provisions above, a recipient may use your version of this file under
|
|
||||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
||||||
*
|
|
||||||
* ***** END LICENSE BLOCK ***** */
|
|
||||||
|
|
||||||
#include "nsXPathException.h"
|
|
||||||
#include "nsCRT.h"
|
|
||||||
#include "nsIDOMClassInfo.h"
|
|
||||||
#include "nsIBaseDOMException.h"
|
|
||||||
#include "prprf.h"
|
|
||||||
|
|
||||||
static const char kInvalidExpressionErrName[] = "NS_ERROR_DOM_INVALID_EXPRESSION_ERR";
|
|
||||||
static const char kInvalidExpressionErrMessage[] = NS_ERROR_DOM_INVALID_EXPRESSION_MSG;
|
|
||||||
static const char kTypeErrName[] = "NS_ERROR_DOM_TYPE_ERR";
|
|
||||||
static const char kTypeErrMessage[] = NS_ERROR_DOM_TYPE_MSG;
|
|
||||||
|
|
||||||
static void
|
|
||||||
TXResultToNameAndMessage(nsresult aNSResult,
|
|
||||||
const char** aName,
|
|
||||||
const char** aMessage);
|
|
||||||
|
|
||||||
void
|
|
||||||
TXResultToNameAndMessage(nsresult aNSResult,
|
|
||||||
const char** aName,
|
|
||||||
const char** aMessage)
|
|
||||||
{
|
|
||||||
if (aNSResult == NS_ERROR_DOM_INVALID_EXPRESSION_ERR) {
|
|
||||||
*aName = kInvalidExpressionErrName;
|
|
||||||
*aMessage = kInvalidExpressionErrMessage;
|
|
||||||
}
|
|
||||||
else if (aNSResult == NS_ERROR_DOM_TYPE_ERR) {
|
|
||||||
*aName = kTypeErrName;
|
|
||||||
*aMessage = kTypeErrMessage;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
NS_WARNING("Huh, someone is throwing non-XPath DOM errors using the XPath DOM module!");
|
|
||||||
*aName = nsnull;
|
|
||||||
*aMessage = nsnull;
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
IMPL_DOM_EXCEPTION_HEAD(nsXPathException, nsIDOMXPathException)
|
|
||||||
NS_DECL_NSIDOMXPATHEXCEPTION
|
|
||||||
IMPL_DOM_EXCEPTION_TAIL(nsXPathException, nsIDOMXPathException, XPathException,
|
|
||||||
NS_ERROR_MODULE_DOM_XPATH, TXResultToNameAndMessage)
|
|
||||||
|
|
||||||
NS_IMETHODIMP
|
|
||||||
nsXPathException::GetCode(PRUint16* aCode)
|
|
||||||
{
|
|
||||||
NS_ENSURE_ARG_POINTER(aCode);
|
|
||||||
nsresult result;
|
|
||||||
mBase->GetResult(&result);
|
|
||||||
*aCode = NS_ERROR_GET_CODE(result);
|
|
||||||
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
NS_IMPL_ISUPPORTS1(nsXPathExceptionProvider, nsIExceptionProvider)
|
|
||||||
|
|
||||||
nsXPathExceptionProvider::nsXPathExceptionProvider()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
nsXPathExceptionProvider::~nsXPathExceptionProvider()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
NS_IMETHODIMP
|
|
||||||
nsXPathExceptionProvider::GetException(nsresult aNSResult,
|
|
||||||
nsIException *aDefaultException,
|
|
||||||
nsIException **aException)
|
|
||||||
{
|
|
||||||
NS_ENSURE_ARG_POINTER(aException);
|
|
||||||
|
|
||||||
NS_NewXPathException(aNSResult, aDefaultException, aException);
|
|
||||||
NS_ENSURE_TRUE(*aException, NS_ERROR_OUT_OF_MEMORY);
|
|
||||||
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
Загрузка…
Ссылка в новой задаче