1 /* Default error handlers for CPP Library.
2 Copyright (C) 1986-2016 Free Software Foundation, Inc.
3 Written by Per Bothner, 1994.
4 Based on CCCP program by Paul Rubin, June 1986
5 Adapted to ANSI C, Richard Stallman, Jan 1987
7 This program is free software; you can redistribute it and/or modify it
8 under the terms of the GNU General Public License as published by the
9 Free Software Foundation; either version 3, or (at your option) any
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>.
21 In other words, you are welcome to use, share and improve this program.
22 You are forbidden to forbid anyone else to use, share and improve
23 what you give them. Help stamp out software-hoarding! */
30 /* Print a diagnostic at the given location. */
32 ATTRIBUTE_FPTR_PRINTF(5,0)
34 cpp_diagnostic_at_richloc (cpp_reader
* pfile
, int level
, int reason
,
35 rich_location
*richloc
,
36 const char *msgid
, va_list *ap
)
42 ret
= pfile
->cb
.error (pfile
, level
, reason
, richloc
, _(msgid
), ap
);
47 /* Print a diagnostic at the given location. */
49 ATTRIBUTE_FPTR_PRINTF(5,0)
51 cpp_diagnostic_at (cpp_reader
* pfile
, int level
, int reason
,
52 source_location src_loc
,
53 const char *msgid
, va_list *ap
)
59 rich_location
richloc (pfile
->line_table
, src_loc
);
60 ret
= pfile
->cb
.error (pfile
, level
, reason
, &richloc
, _(msgid
), ap
);
65 /* Print a diagnostic at the location of the previously lexed token. */
67 ATTRIBUTE_FPTR_PRINTF(4,0)
69 cpp_diagnostic (cpp_reader
* pfile
, int level
, int reason
,
70 const char *msgid
, va_list *ap
)
72 source_location src_loc
;
74 if (CPP_OPTION (pfile
, traditional
))
76 if (pfile
->state
.in_directive
)
77 src_loc
= pfile
->directive_line
;
79 src_loc
= pfile
->line_table
->highest_line
;
81 /* We don't want to refer to a token before the beginning of the
82 current run -- that is invalid. */
83 else if (pfile
->cur_token
== pfile
->cur_run
->base
)
89 src_loc
= pfile
->cur_token
[-1].src_loc
;
91 return cpp_diagnostic_at (pfile
, level
, reason
, src_loc
, msgid
, ap
);
94 /* Print a warning or error, depending on the value of LEVEL. */
97 cpp_error (cpp_reader
* pfile
, int level
, const char *msgid
, ...)
102 va_start (ap
, msgid
);
104 ret
= cpp_diagnostic (pfile
, level
, CPP_W_NONE
, msgid
, &ap
);
110 /* Print a warning. The warning reason may be given in REASON. */
113 cpp_warning (cpp_reader
* pfile
, int reason
, const char *msgid
, ...)
118 va_start (ap
, msgid
);
120 ret
= cpp_diagnostic (pfile
, CPP_DL_WARNING
, reason
, msgid
, &ap
);
126 /* Print a pedantic warning. The warning reason may be given in REASON. */
129 cpp_pedwarning (cpp_reader
* pfile
, int reason
, const char *msgid
, ...)
134 va_start (ap
, msgid
);
136 ret
= cpp_diagnostic (pfile
, CPP_DL_PEDWARN
, reason
, msgid
, &ap
);
142 /* Print a warning, including system headers. The warning reason may be
146 cpp_warning_syshdr (cpp_reader
* pfile
, int reason
, const char *msgid
, ...)
151 va_start (ap
, msgid
);
153 ret
= cpp_diagnostic (pfile
, CPP_DL_WARNING_SYSHDR
, reason
, msgid
, &ap
);
159 /* Print a diagnostic at a specific location. */
161 ATTRIBUTE_FPTR_PRINTF(6,0)
163 cpp_diagnostic_with_line (cpp_reader
* pfile
, int level
, int reason
,
164 source_location src_loc
, unsigned int column
,
165 const char *msgid
, va_list *ap
)
169 if (!pfile
->cb
.error
)
171 rich_location
richloc (pfile
->line_table
, src_loc
);
173 richloc
.override_column (column
);
174 ret
= pfile
->cb
.error (pfile
, level
, reason
, &richloc
, _(msgid
), ap
);
179 /* Print a warning or error, depending on the value of LEVEL. */
182 cpp_error_with_line (cpp_reader
*pfile
, int level
,
183 source_location src_loc
, unsigned int column
,
184 const char *msgid
, ...)
189 va_start (ap
, msgid
);
191 ret
= cpp_diagnostic_with_line (pfile
, level
, CPP_W_NONE
, src_loc
,
198 /* Print a warning. The warning reason may be given in REASON. */
201 cpp_warning_with_line (cpp_reader
*pfile
, int reason
,
202 source_location src_loc
, unsigned int column
,
203 const char *msgid
, ...)
208 va_start (ap
, msgid
);
210 ret
= cpp_diagnostic_with_line (pfile
, CPP_DL_WARNING
, reason
, src_loc
,
217 /* Print a pedantic warning. The warning reason may be given in REASON. */
220 cpp_pedwarning_with_line (cpp_reader
*pfile
, int reason
,
221 source_location src_loc
, unsigned int column
,
222 const char *msgid
, ...)
227 va_start (ap
, msgid
);
229 ret
= cpp_diagnostic_with_line (pfile
, CPP_DL_PEDWARN
, reason
, src_loc
,
236 /* Print a warning, including system headers. The warning reason may be
240 cpp_warning_with_line_syshdr (cpp_reader
*pfile
, int reason
,
241 source_location src_loc
, unsigned int column
,
242 const char *msgid
, ...)
247 va_start (ap
, msgid
);
249 ret
= cpp_diagnostic_with_line (pfile
, CPP_DL_WARNING_SYSHDR
, reason
, src_loc
,
256 /* As cpp_error, but use SRC_LOC as the location of the error, without
257 a column override. */
260 cpp_error_at (cpp_reader
* pfile
, int level
, source_location src_loc
,
261 const char *msgid
, ...)
266 va_start (ap
, msgid
);
268 ret
= cpp_diagnostic_at (pfile
, level
, CPP_W_NONE
, src_loc
,
275 /* As cpp_error, but use RICHLOC as the location of the error, without
276 a column override. */
279 cpp_error_at_richloc (cpp_reader
* pfile
, int level
, rich_location
*richloc
,
280 const char *msgid
, ...)
285 va_start (ap
, msgid
);
287 ret
= cpp_diagnostic_at_richloc (pfile
, level
, CPP_W_NONE
, richloc
,
294 /* Print a warning or error, depending on the value of LEVEL. Include
295 information from errno. */
298 cpp_errno (cpp_reader
*pfile
, int level
, const char *msgid
)
300 return cpp_error (pfile
, level
, "%s: %s", _(msgid
), xstrerror (errno
));
303 /* Print a warning or error, depending on the value of LEVEL. Include
304 information from errno. Unlike cpp_errno, the argument is a filename
305 that is not localized, but "" is replaced with localized "stdout". */
308 cpp_errno_filename (cpp_reader
*pfile
, int level
, const char *filename
,
311 if (filename
[0] == '\0')
312 filename
= _("stdout");
314 return cpp_error_at (pfile
, level
, loc
, "%s: %s", filename
,