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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
/*
* Copyright 2018 Google, Inc.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met: redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer;
* redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution;
* neither the name of the copyright holders nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* Authors: Gabe Black
*/
#ifndef __SYSTEMC_EXT_UTIL_SC_REPORT_HH__
#define __SYSTEMC_EXT_UTIL_SC_REPORT_HH__
#include <exception>
#include <string>
#include "systemc/ext/core/sc_time.hh"
namespace sc_core
{
enum sc_severity
{
SC_INFO = 0,
SC_WARNING,
SC_ERROR,
SC_FATAL,
SC_MAX_SEVERITY
};
enum sc_verbosity
{
SC_NONE = 0,
SC_LOW = 100,
SC_MEDIUM = 200,
SC_HIGH = 300,
SC_FULL = 400,
SC_DEBUG = 500
};
class sc_report_handler;
class sc_report : public std::exception
{
public:
sc_report(const sc_report &);
sc_report &operator = (const sc_report &);
virtual ~sc_report() throw();
sc_severity get_severity() const { return _severity; }
const char *get_msg_type() const { return _msgType; }
const char *get_msg() const { return _msg; }
int get_verbosity() const { return _verbosity; }
const char *get_file_name() const { return _fileName; }
int get_line_number() const { return _lineNumber; }
const sc_time &get_time() const { return _time; }
const char *get_process_name() const { return _processName; }
virtual const char *what() const throw();
// Deprecated
static const char *get_message(int id);
static bool is_suppressed(int id);
static void make_warnings_errors(bool);
static void register_id(int id, const char *msg);
static void suppress_id(int id, bool); // Only for info or warning.
static void suppress_infos(bool);
static void suppress_warnings(bool);
int get_id() const { return _id; }
private:
friend class sc_report_handler;
sc_report(sc_severity _severity,
const char *_msgType,
const char *_msg,
int _verbosity,
const char *_fileName,
int _lineNumber,
sc_time _time,
const char *_processName,
int _id);
sc_severity _severity;
const char *_msgType;
const char *_msg;
int _verbosity;
const char *_fileName;
int _lineNumber;
sc_time _time;
const char *_processName;
int _id;
std::string _what;
};
// A non-standard function the Accellera datatypes rely on.
[[noreturn]] void sc_abort();
} // namespace sc_core
#endif //__SYSTEMC_EXT_UTIL_SC_REPORT_HH__
|