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