]> git.saurik.com Git - bison.git/blame_incremental - src/getargs.h
Update to GPLv3.
[bison.git] / src / getargs.h
... / ...
CommitLineData
1/* Parse command line arguments for bison.
2
3 Copyright (C) 1984, 1986, 1989, 1992, 2000, 2001, 2002, 2003, 2004,
4 2005, 2006, 2007 Free Software Foundation, Inc.
5
6 This file is part of Bison, the GNU Compiler Compiler.
7
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.
12
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.
17
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20
21#ifndef GETARGS_H_
22# define GETARGS_H_
23
24#include "location.h"
25
26extern char *program_name;
27
28/* flags set by % directives */
29
30/* for -S */
31extern char const *skeleton;
32
33/* for -I */
34extern char const *include;
35
36extern bool debug_flag; /* for -t */
37extern bool defines_flag; /* for -d */
38extern bool graph_flag; /* for -g */
39extern bool locations_flag;
40extern bool no_lines_flag; /* for -l */
41extern bool token_table_flag; /* for -k */
42extern bool yacc_flag; /* for -y */
43
44extern bool error_verbose;
45
46
47/* GLR_PARSER is true if the input file says to use the GLR
48 (Generalized LR) parser, and to output some additional information
49 used by the GLR algorithm. */
50
51extern bool glr_parser;
52
53/* PULL_PARSER is true if should generate a pull parser. */
54
55extern bool pull_parser;
56
57/* PURE_PARSER is true if should generate a parser that is all pure
58 and reentrant. */
59
60extern bool pure_parser;
61
62/* PUSH_PARSER is true if should generate a push parser. */
63
64extern bool push_parser;
65
66/* NONDETERMINISTIC_PARSER is true iff conflicts are accepted. This
67 is used by the GLR parser, and might be used in BackTracking
68 parsers too. */
69
70extern bool nondeterministic_parser;
71
72
73/* --language. */
74struct bison_language
75{
76 char language[sizeof "Java"];
77 char skeleton[sizeof "java-skel.m4"];
78 char src_extension[sizeof ".java"];
79 char header_extension[sizeof ".java"];
80 bool add_tab;
81};
82
83extern struct bison_language const *language;
84
85/*-----------.
86| --report. |
87`-----------*/
88
89enum report
90 {
91 report_none = 0,
92 report_states = 1 << 0,
93 report_itemsets = 1 << 1,
94 report_lookahead_tokens = 1 << 2,
95 report_solved_conflicts = 1 << 3,
96 report_all = ~0
97 };
98/** What appears in the *.output file. */
99extern int report_flag;
100
101/*----------.
102| --trace. |
103`----------*/
104enum trace
105 {
106 trace_none = 0, /**< No traces. */
107 trace_scan = 1 << 0, /**< Grammar scanner traces. */
108 trace_parse = 1 << 1, /**< Grammar parser traces. */
109 trace_resource = 1 << 2, /**< Memory allocation. */
110 trace_sets = 1 << 3, /**< Grammar sets: firsts, nullable etc. */
111 trace_bitsets = 1 << 4, /**< Use of bitsets. */
112 trace_tools = 1 << 5, /**< m4 invocation. */
113 trace_automaton = 1 << 6, /**< Construction of the automaton. */
114 trace_grammar = 1 << 7, /**< Reading, reducing the grammar. */
115 trace_time = 1 << 8, /**< Time consumption. */
116 trace_skeleton = 1 << 9, /**< Skeleton postprocessing. */
117 trace_m4 = 1 << 10, /**< M4 traces. */
118 trace_all = ~0 /**< All of the above. */
119 };
120/** What debug items bison displays during its run. */
121extern int trace_flag;
122
123/*-------------.
124| --warnings. |
125`-------------*/
126
127enum warnings
128 {
129 warnings_none = 0, /**< Issue no warnings. */
130 warnings_error = 1 << 0, /**< Warnings are treated as errors. */
131 warnings_midrule_values = 1 << 1, /**< Unset or unused midrule values. */
132 warnings_yacc = 1 << 2, /**< POSIXME. */
133 warnings_all = ~warnings_error /**< All above warnings. */
134 };
135/** What warnings are issued. */
136extern int warnings_flag;
137
138
139/** Process the command line arguments.
140 *
141 * \param argc size of \a argv
142 * \param argv list of arguments.
143 */
144void getargs (int argc, char *argv[]);
145
146/* Used by parse-gram.y. */
147void language_argmatch (char const *arg, int prio, location const *loc);
148void skeleton_arg (const char *arg, int prio, location const *loc);
149
150#endif /* !GETARGS_H_ */