blob: 4de2df0e6b961543c4c9242d77a10a2502f63169 (
plain)
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
|
// **********************************************************************
//
// Copyright (c) 2001
// MutableRealms, Inc.
// Huntsville, AL, USA
//
// All Rights Reserved
//
// **********************************************************************
#ifndef ICE_SSL_CONFIG_ERROR_REPORTER_H
#define ICE_SSL_CONFIG_ERROR_REPORTER_H
#include <iostream>
#include <util/XercesDefs.hpp>
#include <dom/DOMString.hpp>
#include <sax/ErrorHandler.hpp>
#include <Ice/TraceLevels.h>
#include <Ice/Logger.h>
namespace IceSecurity
{
namespace Ssl
{
using IceInternal::TraceLevelsPtr;
using Ice::LoggerPtr;
class ErrorReporter : public ErrorHandler
{
public:
ErrorReporter(TraceLevelsPtr traceLevels, LoggerPtr logger) :
_sawErrors(false),
_traceLevels(traceLevels),
_logger(logger)
{
}
~ErrorReporter() { }
// Implementation of the error handler interface.
void warning(const SAXParseException& toCatch);
void error(const SAXParseException& toCatch);
void fatalError(const SAXParseException& toCatch);
void resetErrors();
inline bool getSawErrors() const { return _sawErrors; };
private:
// This is set if we get any errors, and is queryable via a getter method.
// It's used by the main code to suppress output if there are errors.
bool _sawErrors;
TraceLevelsPtr _traceLevels;
LoggerPtr _logger;
};
using std::ostream;
inline ostream&
operator << (ostream& target, const DOMString& s)
{
char *p = s.transcode();
target << p;
delete [] p;
return target;
}
}
}
#endif
|