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.10 2003/02/05 18:53:22 tng Exp $
61
#include <xercesc/util/XercesDefs.hpp>
62
#include <xercesc/sax/ErrorHandler.hpp>
66
XERCES_CPP_NAMESPACE_USE
69
class DOMTreeErrorReporter : public ErrorHandler
72
// -----------------------------------------------------------------------
73
// Constructors and Destructor
74
// -----------------------------------------------------------------------
75
DOMTreeErrorReporter() :
80
~DOMTreeErrorReporter()
85
// -----------------------------------------------------------------------
86
// Implementation of the error handler interface
87
// -----------------------------------------------------------------------
88
void warning(const SAXParseException& toCatch);
89
void error(const SAXParseException& toCatch);
90
void fatalError(const SAXParseException& toCatch);
93
// -----------------------------------------------------------------------
95
// -----------------------------------------------------------------------
96
bool getSawErrors() const;
98
// -----------------------------------------------------------------------
99
// Private data members
102
// This is set if we get any errors, and is queryable via a getter
103
// method. Its used by the main code to suppress output if there are
105
// -----------------------------------------------------------------------
109
inline bool DOMTreeErrorReporter::getSawErrors() const
114
// ---------------------------------------------------------------------------
115
// This is a simple class that lets us do easy (though not terribly efficient)
116
// trancoding of XMLCh data to local code page for display.
117
// ---------------------------------------------------------------------------
121
// -----------------------------------------------------------------------
122
// Constructors and Destructor
123
// -----------------------------------------------------------------------
124
StrX(const XMLCh* const toTranscode)
126
// Call the private transcoding method
127
fLocalForm = XMLString::transcode(toTranscode);
132
XMLString::release(&fLocalForm);
136
// -----------------------------------------------------------------------
138
// -----------------------------------------------------------------------
139
const char* localForm() const
145
// -----------------------------------------------------------------------
146
// Private data members
149
// This is the local code page form of the string.
150
// -----------------------------------------------------------------------
154
inline std::ostream& operator<<(std::ostream& target, const StrX& toDump)
156
target << toDump.localForm();