]> git.saurik.com Git - bison.git/blame_incremental - src/complain.c
2007-01-30 Paolo Bonzini <bonzini@gnu.org>
[bison.git] / src / complain.c
... / ...
CommitLineData
1/* Declaration for error-reporting function for Bison.
2
3 Copyright (C) 2000, 2001, 2002, 2004, 2005, 2006
4 Free Software Foundation, Inc.
5
6 This program is free software; you can redistribute it and/or modify it
7 under the terms of the GNU General Public License as published by the
8 Free Software Foundation; either version 2, or (at your option) any
9 later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19 USA. */
20
21/* Based on error.c and error.h,
22 written by David MacKenzie <djm@gnu.ai.mit.edu>. */
23
24#include <config.h>
25#include "system.h"
26
27#include <stdarg.h>
28
29#include "complain.h"
30#include "files.h"
31#include "getargs.h"
32
33bool complaint_issued;
34
35\f
36
37/** Report an error message.
38 *
39 * \param loc the location, defaulting to the current file,
40 * or the program name.
41 * \param prefix put before the message (e.g., "warning").
42 * \param message the error message, a printf format string.
43 * \param args the arguments of the format string.
44 */
45static
46void
47error_message (location *loc,
48 const char *prefix,
49 const char *message, va_list args)
50{
51 if (loc)
52 location_print (stderr, *loc);
53 else
54 fputs (current_file ? current_file : program_name, stderr);
55 fputs (": ", stderr);
56
57 if (prefix)
58 fprintf (stderr, "%s: ", prefix);
59
60 vfprintf (stderr, message, args);
61 va_end (args);
62 putc ('\n', stderr);
63 fflush (stderr);
64}
65
66/** Wrap error_message() with varargs handling. */
67#define ERROR_MESSAGE(Loc, Prefix, Message) \
68{ \
69 va_list args; \
70 va_start (args, Message); \
71 error_message (Loc, Prefix, Message, args); \
72}
73
74
75/*--------------------------------.
76| Report a warning, and proceed. |
77`--------------------------------*/
78
79static void
80set_warning_issued (void)
81{
82 static bool warning_issued = false;
83 if (!warning_issued && (warnings_flag & warnings_error))
84 {
85 fprintf (stderr, "%s: warnings being treated as errors\n", program_name);
86 complaint_issued = true;
87 }
88 warning_issued = true;
89}
90
91void
92warn_at (location loc, const char *message, ...)
93{
94 set_warning_issued ();
95 ERROR_MESSAGE (&loc, _("warning"), message);
96}
97
98void
99warn (const char *message, ...)
100{
101 set_warning_issued ();
102 ERROR_MESSAGE (NULL, _("warning"), message);
103}
104
105
106/*-----------------------------------------------------------.
107| An error has occurred, but we can proceed, and die later. |
108`-----------------------------------------------------------*/
109
110void
111complain_at (location loc, const char *message, ...)
112{
113 ERROR_MESSAGE (&loc, NULL, message);
114 complaint_issued = true;
115}
116
117void
118complain (const char *message, ...)
119{
120 ERROR_MESSAGE (NULL, NULL, message);
121 complaint_issued = true;
122}
123
124
125/*-------------------------------------------------.
126| A severe error has occurred, we cannot proceed. |
127`-------------------------------------------------*/
128
129void
130fatal_at (location loc, const char *message, ...)
131{
132 ERROR_MESSAGE (&loc, _("fatal error"), message);
133 exit (EXIT_FAILURE);
134}
135
136void
137fatal (const char *message, ...)
138{
139 ERROR_MESSAGE (NULL, _("fatal error"), message);
140 exit (EXIT_FAILURE);
141}