]> git.saurik.com Git - bison.git/blame - src/getargs.h
Fix unexpanded macros in GLR defines file.
[bison.git] / src / getargs.h
CommitLineData
ceed8467 1/* Parse command line arguments for bison.
8405b70c
PB
2
3 Copyright (C) 1984, 1986, 1989, 1992, 2000, 2001, 2002, 2003, 2004,
4b1ebc49 4 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
ceed8467
AD
5
6 This file is part of Bison, the GNU Compiler Compiler.
7
f16b0819
PE
8 This program is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
ceed8467 12
f16b0819
PE
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
ceed8467
AD
17
18 You should have received a copy of the GNU General Public License
f16b0819 19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
ceed8467 20
b2ca4022
AD
21#ifndef GETARGS_H_
22# define GETARGS_H_
23
0e021770
PE
24#include "location.h"
25
26extern char *program_name;
4b1ebc49 27enum { command_line_prio, grammar_prio, default_prio };
0e021770 28
ceed8467 29/* flags set by % directives */
04098407
PE
30
31/* for -S */
32extern char const *skeleton;
4b1ebc49 33extern int skeleton_prio;
04098407
PE
34
35/* for -I */
36extern char const *include;
ceed8467 37
d0829076
PE
38extern bool debug_flag; /* for -t */
39extern bool defines_flag; /* for -d */
4e83ea15 40extern bool graph_flag; /* for -g */
41d7a5f2 41extern bool xml_flag; /* for -x */
d0829076
PE
42extern bool locations_flag;
43extern bool no_lines_flag; /* for -l */
d0829076 44extern bool token_table_flag; /* for -k */
d0829076 45extern bool yacc_flag; /* for -y */
273a74fa 46
4e83ea15
AD
47extern bool error_verbose;
48
49
916708d5
AD
50/* GLR_PARSER is true if the input file says to use the GLR
51 (Generalized LR) parser, and to output some additional information
52 used by the GLR algorithm. */
53
54extern bool glr_parser;
55
916708d5
AD
56/* NONDETERMINISTIC_PARSER is true iff conflicts are accepted. This
57 is used by the GLR parser, and might be used in BackTracking
58 parsers too. */
59
60extern bool nondeterministic_parser;
61
7b42569e 62
0e021770
PE
63/* --language. */
64struct bison_language
65{
8405b70c
PB
66 char language[sizeof "Java"];
67 char skeleton[sizeof "java-skel.m4"];
68 char src_extension[sizeof ".java"];
69 char header_extension[sizeof ".java"];
0e021770
PE
70 bool add_tab;
71};
72
4b1ebc49 73extern int language_prio;
0e021770
PE
74extern struct bison_language const *language;
75
7b42569e
AD
76/*-----------.
77| --report. |
78`-----------*/
79
e8a0acd6 80enum report
ec3bc396 81 {
273a74fa
AD
82 report_none = 0,
83 report_states = 1 << 0,
84 report_itemsets = 1 << 1,
742e4900 85 report_lookahead_tokens = 1 << 2,
b408954b 86 report_solved_conflicts = 1 << 3,
273a74fa 87 report_all = ~0
ec3bc396 88 };
b8a41559 89/** What appears in the *.output file. */
ec3bc396
AD
90extern int report_flag;
91
7b42569e
AD
92/*----------.
93| --trace. |
94`----------*/
b8a41559
AD
95enum trace
96 {
97 trace_none = 0, /**< No traces. */
98 trace_scan = 1 << 0, /**< Grammar scanner traces. */
99 trace_parse = 1 << 1, /**< Grammar parser traces. */
100 trace_resource = 1 << 2, /**< Memory allocation. */
101 trace_sets = 1 << 3, /**< Grammar sets: firsts, nullable etc. */
102 trace_bitsets = 1 << 4, /**< Use of bitsets. */
103 trace_tools = 1 << 5, /**< m4 invocation. */
104 trace_automaton = 1 << 6, /**< Construction of the automaton. */
105 trace_grammar = 1 << 7, /**< Reading, reducing the grammar. */
106 trace_time = 1 << 8, /**< Time consumption. */
107 trace_skeleton = 1 << 9, /**< Skeleton postprocessing. */
108 trace_m4 = 1 << 10, /**< M4 traces. */
109 trace_all = ~0 /**< All of the above. */
110 };
111/** What debug items bison displays during its run. */
112extern int trace_flag;
113
7b42569e
AD
114/*-------------.
115| --warnings. |
116`-------------*/
117
118enum warnings
119 {
120 warnings_none = 0, /**< Issue no warnings. */
121 warnings_error = 1 << 0, /**< Warnings are treated as errors. */
17bd8a73
JD
122 warnings_midrule_values = 1 << 1, /**< Unset or unused midrule values. */
123 warnings_yacc = 1 << 2, /**< POSIXME. */
89eb3c76 124 warnings_all = ~warnings_error /**< All above warnings. */
7b42569e
AD
125 };
126/** What warnings are issued. */
127extern int warnings_flag;
128
129
130/** Process the command line arguments.
131 *
132 * \param argc size of \a argv
133 * \param argv list of arguments.
134 */
d33cb3ae 135void getargs (int argc, char *argv[]);
b2ca4022 136
0e021770
PE
137/* Used by parse-gram.y. */
138void language_argmatch (char const *arg, int prio, location const *loc);
139void skeleton_arg (const char *arg, int prio, location const *loc);
140
b2ca4022 141#endif /* !GETARGS_H_ */