2
* The Apache Software License, Version 1.1
4
* Copyright (c) 1999-2002 The Apache Software Foundation. All rights
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
11
* 1. Redistributions of source code must retain the above copyright
12
* notice, this list of conditions and the following disclaimer.
14
* 2. Redistributions in binary form must reproduce the above copyright
15
* notice, this list of conditions and the following disclaimer in
16
* the documentation and/or other materials provided with the
19
* 3. The end-user documentation included with the redistribution,
20
* if any, must include the following acknowledgment:
21
* "This product includes software developed by the
22
* Apache Software Foundation (http://www.apache.org/)."
23
* Alternately, this acknowledgment may appear in the software itself,
24
* if and wherever such third-party acknowledgments normally appear.
26
* 4. The names "Xerces" and "Apache Software Foundation" must
27
* not be used to endorse or promote products derived from this
28
* software without prior written permission. For written
29
* permission, please contact apache\@apache.org.
31
* 5. Products derived from this software may not be called "Apache",
32
* nor may "Apache" appear in their name, without prior written
33
* permission of the Apache Software Foundation.
35
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38
* DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47
* ====================================================================
49
* This software consists of voluntary contributions made by many
50
* individuals on behalf of the Apache Software Foundation, and was
51
* originally based on software copyright (c) 1999, International
52
* Business Machines, Inc., http://www.ibm.com . For more information
53
* on the Apache Software Foundation, please see
54
* <http://www.apache.org/>.
58
* $Id: DOMTreeErrorReporter.hpp,v 1.8 2002/05/21 19:18:18 tng Exp $
61
#include <xercesc/util/XercesDefs.hpp>
62
#include <xercesc/sax/ErrorHandler.hpp>
67
class DOMTreeErrorReporter : public ErrorHandler
70
// -----------------------------------------------------------------------
71
// Constructors and Destructor
72
// -----------------------------------------------------------------------
73
DOMTreeErrorReporter() :
78
~DOMTreeErrorReporter()
83
// -----------------------------------------------------------------------
84
// Implementation of the error handler interface
85
// -----------------------------------------------------------------------
86
void warning(const SAXParseException& toCatch);
87
void error(const SAXParseException& toCatch);
88
void fatalError(const SAXParseException& toCatch);
91
// -----------------------------------------------------------------------
93
// -----------------------------------------------------------------------
94
bool getSawErrors() const;
96
// -----------------------------------------------------------------------
97
// Private data members
100
// This is set if we get any errors, and is queryable via a getter
101
// method. Its used by the main code to suppress output if there are
103
// -----------------------------------------------------------------------
107
inline bool DOMTreeErrorReporter::getSawErrors() const
112
// ---------------------------------------------------------------------------
113
// This is a simple class that lets us do easy (though not terribly efficient)
114
// trancoding of XMLCh data to local code page for display.
115
// ---------------------------------------------------------------------------
119
// -----------------------------------------------------------------------
120
// Constructors and Destructor
121
// -----------------------------------------------------------------------
122
StrX(const XMLCh* const toTranscode)
124
// Call the private transcoding method
125
fLocalForm = XMLString::transcode(toTranscode);
130
delete [] fLocalForm;
134
// -----------------------------------------------------------------------
136
// -----------------------------------------------------------------------
137
const char* localForm() const
143
// -----------------------------------------------------------------------
144
// Private data members
147
// This is the local code page form of the string.
148
// -----------------------------------------------------------------------
152
inline ostream& operator<<(ostream& target, const StrX& toDump)
154
target << toDump.localForm();