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
|
/* Various declarations for language-independent diagnostics
subroutines that are only for use in the compilers proper and not
the driver or other programs.
Copyright (C) 2000-2024 Free Software Foundation, Inc.
This file is part of GCC.
GCC is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 3, or (at your option) any later
version.
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with GCC; see the file COPYING3. If not see
<http://www.gnu.org/licenses/>. */
#ifndef GCC_TREE_DIAGNOSTIC_H
#define GCC_TREE_DIAGNOSTIC_H
/* TREE_BLOCK if the diagnostic is to be reported in some inline
function inlined into other function, otherwise NULL. */
#define diagnostic_abstract_origin(DI) \
((tree) diagnostic_info_auxiliary_data (DI))
/* Function of last diagnostic message; more generally, function such
that if next diagnostic message is in it then we don't have to
mention the function name. */
#define diagnostic_last_function(DC) \
((tree) diagnostic_context_auxiliary_data (DC))
/* True if the last function in which a diagnostic was reported is
different from the current one. */
#define diagnostic_last_function_changed(DC, DI) \
(diagnostic_last_function (DC) != (diagnostic_abstract_origin (DI) \
? diagnostic_abstract_origin (DI) \
: current_function_decl))
/* Remember the current function as being the last one in which we report
a diagnostic. */
#define diagnostic_set_last_function(DC, DI) \
diagnostic_context_auxiliary_data (DC) \
= (((DI) && diagnostic_abstract_origin (DI)) \
? diagnostic_abstract_origin (DI) \
: current_function_decl)
void diagnostic_report_current_function (diagnostic_context *,
const diagnostic_info *);
void tree_diagnostics_defaults (diagnostic_context *context);
bool default_tree_printer (pretty_printer *, text_info *, const char *,
int, bool, bool, bool, bool *, pp_token_list &);
/* A subclass of pretty_printer for writing "dump" functions.
Wires itself up to a FILE *, and colorizes if it's stderr and
the user requested colorization. */
class tree_dump_pretty_printer : public pretty_printer
{
public:
tree_dump_pretty_printer (FILE *outf)
{
pp_format_decoder (this) = default_tree_printer;
if (outf == stderr)
pp_show_color (this) = pp_show_color (global_dc->m_printer);
set_output_stream (outf);
}
~tree_dump_pretty_printer ()
{
pp_flush (this);
}
};
#endif /* ! GCC_TREE_DIAGNOSTIC_H */
|