1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
|
/*
** ClanLib SDK
** Copyright (c) 1997-2005 The ClanLib Team
**
** This software is provided 'as-is', without any express or implied
** warranty. In no event will the authors be held liable for any damages
** arising from the use of this software.
**
** Permission is granted to anyone to use this software for any purpose,
** including commercial applications, and to alter it and redistribute it
** freely, subject to the following restrictions:
**
** 1. The origin of this software must not be misrepresented; you must not
** claim that you wrote the original software. If you use this software
** in a product, an acknowledgment in the product documentation would be
** appreciated but is not required.
** 2. Altered source versions must be plainly marked as such, and must not be
** misrepresented as being the original software.
** 3. This notice may not be removed or altered from any source distribution.
**
** Note: Some of the libraries ClanLib may link to may have additional
** requirements or restrictions.
**
** File Author(s):
**
** Magnus Norddahl
** (if your name is missing here, please add it)
*/
#include "Core/precomp.h"
#include "API/Core/XML/dom_exception.h"
#include "API/Core/System/clanstring.h"
/////////////////////////////////////////////////////////////////////////////
// CL_DomException construction:
static std::string code_to_message(unsigned short code)
{
switch (code)
{
case CL_DomException::DOMSTRING_SIZE_ERR:
return "DOMSTRING_SIZE_ERR: Specified range of text does not fit into a DOMString";
case CL_DomException::HIERARCHY_REQUEST_ERR:
return "HIERARCHY_REQUEST_ERR: Attemped to insert node where it doesn't belong";
case CL_DomException::INDEX_SIZE_ERR:
return "INDEX_SIZE_ERR: Index or size is negative, or greater than the allowed value";
case CL_DomException::INUSE_ATTRIBUTE_ERR:
return "INUSE_ATTRIBUTE_ERR: An attempt was made to add an attribute that is already in use elsewhere";
case CL_DomException::INVALID_CHARACTER_ERR:
return "INVALID_CHARACTER_ERR: An invalid or illegal character was specified, such as in a name";
case CL_DomException::NOT_FOUND_ERR:
return "NOT_FOUND_ERR: An attempt was made to reference a node in a context where it does not exist";
case CL_DomException::NOT_SUPPORTED_ERR:
return "NOT_SUPPORTED_ERR: The implementation does not support the type of object requested";
case CL_DomException::NO_DATA_ALLOWED_ERR:
return "NO_DATA_ALLOWED_ERR: Data was specified for a node which does not support data";
case CL_DomException::NO_MODIFICATION_ALLOWED_ERR:
return "NO_MODIFICATION_ALLOWED_ERR: An attempt was made to modify an object where modifications are not allowed";
case CL_DomException::WRONG_DOCUMENT_ERR:
return "WRONG_DOCUMENT_ERR: A node was used in a different document than the one that created it";
}
return CL_String::format("Unknown DOM exception code %1", code);
}
CL_DomException::CL_DomException(unsigned short code) : CL_Error(code_to_message(code)), code(code)
{
}
CL_DomException::CL_DomException(const std::string &message, unsigned short code) : CL_Error(message), code(code)
{
}
/////////////////////////////////////////////////////////////////////////////
// CL_DomException attributes:
/////////////////////////////////////////////////////////////////////////////
// CL_DomException implementation:
|