1 /* Declarations of core diagnostic functionality for code that does
2 not need to deal with diagnostic contexts or diagnostic info
3 structures. These functions implicitly use global_dc.
4 Copyright (C) 1998-2025 Free Software Foundation, Inc.
6 This file is part of GCC.
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
22 #ifndef GCC_DIAGNOSTIC_CORE_H
23 #define GCC_DIAGNOSTIC_CORE_H
27 /* Constants used to discriminate diagnostics. */
30 #define DEFINE_DIAGNOSTIC_KIND(K, msgid, C) K,
31 #include "diagnostic.def"
32 #undef DEFINE_DIAGNOSTIC_KIND
33 DK_LAST_DIAGNOSTIC_KIND
,
34 /* This is used for tagging pragma pops in the diagnostic
35 classification history chain. */
37 /* This is used internally to note that a diagnostic is enabled
38 without mandating any specific type. */
42 /* RAII-style class for grouping related diagnostics within global_dc. */
44 class auto_diagnostic_group
47 auto_diagnostic_group ();
48 ~auto_diagnostic_group ();
51 /* RAII-style class for nesting hierarchical diagnostics within global_dc.
52 Any diagnostics emitted within the lifetime of this object
53 will be treated as one level of nesting deeper than diagnostics
54 emitted outside the lifetime of the object. */
56 class auto_diagnostic_nesting_level
59 auto_diagnostic_nesting_level ();
60 ~auto_diagnostic_nesting_level ();
64 class diagnostic_metadata
; /* See diagnostic-metadata.h. */
66 /* A class to use for the ID of an option that controls
67 a particular diagnostic.
68 This is just a wrapper around "int", but better documents
69 the intent of the code. */
71 struct diagnostic_option_id
73 diagnostic_option_id () : m_idx (0) {}
75 diagnostic_option_id (int idx
) : m_idx (idx
) {}
76 /* Ideally we'd take an enum opt_code here, but we don't
77 want to depend on its decl. */
79 bool operator== (diagnostic_option_id other
) const
81 return m_idx
== other
.m_idx
;
87 extern const char *progname
;
89 extern const char *trim_filename (const char *);
91 /* Various functions for emitting diagnostics follow.
92 All of these implicitly use global_dc. */
94 /* If we haven't already defined a front-end-specific diagnostics
95 style, use the generic one. */
96 #ifndef GCC_DIAG_STYLE
97 #define GCC_DIAG_STYLE __gcc_tdiag__
99 /* None of these functions are suitable for ATTRIBUTE_PRINTF, because
100 each language front end can extend them with its own set of format
101 specifiers. We must use custom format checks. */
102 #if (CHECKING_P && GCC_VERSION >= 4001) || GCC_VERSION == BUILDING_GCC_VERSION
103 #define ATTRIBUTE_GCC_DIAG(m, n) __attribute__ ((__format__ (GCC_DIAG_STYLE, m, n))) ATTRIBUTE_NONNULL(m)
105 #define ATTRIBUTE_GCC_DIAG(m, n) ATTRIBUTE_NONNULL(m)
107 extern void internal_error (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2)
109 extern void internal_error_no_backtrace (const char *, ...)
110 ATTRIBUTE_GCC_DIAG(1,2) ATTRIBUTE_NORETURN
;
111 /* Pass one of the OPT_W* from options.h as the first parameter. */
112 extern bool warning (diagnostic_option_id
,
113 const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
114 extern bool warning_n (location_t
,
115 diagnostic_option_id
,
116 unsigned HOST_WIDE_INT
,
117 const char *, const char *, ...)
118 ATTRIBUTE_GCC_DIAG(4,6) ATTRIBUTE_GCC_DIAG(5,6);
119 extern bool warning_n (rich_location
*,
120 diagnostic_option_id
,
121 unsigned HOST_WIDE_INT
,
122 const char *, const char *, ...)
123 ATTRIBUTE_GCC_DIAG(4, 6) ATTRIBUTE_GCC_DIAG(5, 6);
124 extern bool warning_at (location_t
,
125 diagnostic_option_id
,
127 ATTRIBUTE_GCC_DIAG(3,4);
128 extern bool warning_at (rich_location
*,
129 diagnostic_option_id
,
131 ATTRIBUTE_GCC_DIAG(3,4);
132 extern bool warning_meta (rich_location
*,
133 const diagnostic_metadata
&,
134 diagnostic_option_id
,
136 ATTRIBUTE_GCC_DIAG(4,5);
137 extern void error (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
138 extern void error_n (location_t
, unsigned HOST_WIDE_INT
, const char *,
140 ATTRIBUTE_GCC_DIAG(3,5) ATTRIBUTE_GCC_DIAG(4,5);
141 extern void error_at (location_t
, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
142 extern void error_at (rich_location
*, const char *, ...)
143 ATTRIBUTE_GCC_DIAG(2,3);
144 extern void error_meta (rich_location
*, const diagnostic_metadata
&,
146 ATTRIBUTE_GCC_DIAG(3,4);
147 extern void fatal_error (location_t
, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3)
149 /* Pass one of the OPT_W* from options.h as the second parameter. */
150 extern bool pedwarn (location_t
,
151 diagnostic_option_id
,
153 ATTRIBUTE_GCC_DIAG(3,4);
154 extern bool pedwarn (rich_location
*,
155 diagnostic_option_id
,
157 ATTRIBUTE_GCC_DIAG(3,4);
158 extern bool permerror (location_t
, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
159 extern bool permerror (rich_location
*, const char *,
160 ...) ATTRIBUTE_GCC_DIAG(2,3);
161 extern bool permerror_opt (location_t
,
162 diagnostic_option_id
,
164 ATTRIBUTE_GCC_DIAG(3,4);
165 extern bool permerror_opt (rich_location
*,
166 diagnostic_option_id
,
168 ATTRIBUTE_GCC_DIAG(3,4);
169 extern void sorry (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
170 extern void sorry_at (location_t
, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
171 extern void inform (location_t
, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
172 extern void inform (rich_location
*, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
173 extern void inform_n (location_t
, unsigned HOST_WIDE_INT
, const char *,
175 ATTRIBUTE_GCC_DIAG(3,5) ATTRIBUTE_GCC_DIAG(4,5);
176 extern void verbatim (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
177 extern bool emit_diagnostic (diagnostic_t
,
179 diagnostic_option_id
,
180 const char *, ...) ATTRIBUTE_GCC_DIAG(4,5);
181 extern bool emit_diagnostic (diagnostic_t
,
183 diagnostic_option_id
,
184 const char *, ...) ATTRIBUTE_GCC_DIAG(4,5);
185 extern bool emit_diagnostic_valist (diagnostic_t
,
187 diagnostic_option_id
,
188 const char *, va_list *)
189 ATTRIBUTE_GCC_DIAG (4,0);
190 extern bool emit_diagnostic_valist_meta (diagnostic_t
,
192 const diagnostic_metadata
*,
193 diagnostic_option_id
,
195 va_list *) ATTRIBUTE_GCC_DIAG (5,0);
196 extern bool seen_error (void);
199 /* N.B. Unlike all the others, fnotice is just gettext+fprintf, and
200 therefore it can have ATTRIBUTE_PRINTF. */
201 extern void fnotice (FILE *, const char *, ...)
205 #endif /* ! GCC_DIAGNOSTIC_CORE_H */