276164cf912f43e4fc89389168d2cab1484c7e5e
[bison.git] / src / complain.h
1 /* Declaration for error-reporting function for Bison.
2
3 Copyright (C) 2000-2002, 2006, 2009-2012 Free Software Foundation,
4 Inc.
5
6 This program is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any 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, see <http://www.gnu.org/licenses/>. */
18
19 #ifndef COMPLAIN_H_
20 # define COMPLAIN_H_ 1
21
22 # include "location.h"
23
24 /*-------------.
25 | --warnings. |
26 `-------------*/
27
28 typedef enum
29 {
30 Wnone = 0, /**< Issue no warnings. */
31 Wmidrule_values = 1 << 0, /**< Unset or unused midrule values. */
32 Wyacc = 1 << 1, /**< POSIXME. */
33 Wconflicts_sr = 1 << 2, /**< S/R conflicts. */
34 Wconflicts_rr = 1 << 3, /**< R/R conflicts. */
35 Wother = 1 << 4, /**< All other warnings. */
36
37 Werror = 1 << 10, /**< Warnings are treated as errors. */
38 complaint = 1 << 11, /**< All complaints. */
39 fatal = 1 << 12, /**< All fatal errors. */
40 silent = 1 << 13, /**< Do not display the warning type. */
41 Wall = ~Werror /**< All above warnings. */
42 } warnings;
43
44 /** What warnings are issued. */
45 extern warnings warnings_flag;
46
47 /** Display a "[-Wyacc]" like message on stderr. */
48 void warnings_print_categories (warnings warn_flags);
49
50 /** Record that a warning is about to be issued, and treat it as an
51 error if <tt>warnings_flag & Werror</tt>. This is exported
52 only for the sake of Yacc-compatible conflict reports in conflicts.c.
53 All other warnings should be implemented in complain.c and should use
54 the normal warning format. */
55 void set_warning_issued (void);
56
57 /** Make a complaint, but don't specify any location. */
58 void complain (warnings flags, char const *message, ...)
59 __attribute__ ((__format__ (__printf__, 2, 3)));
60
61 /** Make a complaint with location. */
62 void complain_at (location loc, warnings flags, char const *message, ...)
63 __attribute__ ((__format__ (__printf__, 3, 4)));
64
65 /** Make a complaint with location and some indentation. */
66 void complain_at_indent (location loc, warnings flags, unsigned *indent,
67 char const *message, ...)
68 __attribute__ ((__format__ (__printf__, 4, 5)));
69
70 /** Whether an error was reported. */
71 extern bool complaint_issued;
72
73 #endif /* !COMPLAIN_H_ */