]> git.saurik.com Git - bison.git/blame - src/getargs.h
* data/Makefile.am (dist_pkgdata_DATA): Add push.c.
[bison.git] / src / getargs.h
CommitLineData
ceed8467 1/* Parse command line arguments for bison.
4e83ea15 2 Copyright (C) 1984, 1986, 1989, 1992, 2000, 2001, 2002, 2003, 2004, 2005, 2006
ec3bc396 3 Free Software Foundation, Inc.
ceed8467
AD
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
0fb669f9
PE
19 Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
20 02110-1301, USA. */
ceed8467 21
b2ca4022
AD
22#ifndef GETARGS_H_
23# define GETARGS_H_
24
ceed8467 25/* flags set by % directives */
04098407
PE
26
27/* for -S */
28extern char const *skeleton;
29
30/* for -I */
31extern char const *include;
ceed8467 32
d0829076
PE
33extern bool debug_flag; /* for -t */
34extern bool defines_flag; /* for -d */
4e83ea15 35extern bool graph_flag; /* for -g */
d0829076
PE
36extern bool locations_flag;
37extern bool no_lines_flag; /* for -l */
38extern bool no_parser_flag; /* for -n */
39extern bool token_table_flag; /* for -k */
d0829076 40extern bool yacc_flag; /* for -y */
273a74fa 41
4e83ea15
AD
42extern bool error_verbose;
43
44
916708d5
AD
45/* GLR_PARSER is true if the input file says to use the GLR
46 (Generalized LR) parser, and to output some additional information
47 used by the GLR algorithm. */
48
49extern bool glr_parser;
50
51/* PURE_PARSER is true if should generate a parser that is all pure
52 and reentrant. */
53
54extern bool pure_parser;
55
31c10e38
PE
56/* PUSH_PARSER is true if should generate a parser that is capable of being
57 called asynchronously. Is must be pure and reentrant. */
58
59extern bool push_parser;
60
916708d5
AD
61/* NONDETERMINISTIC_PARSER is true iff conflicts are accepted. This
62 is used by the GLR parser, and might be used in BackTracking
63 parsers too. */
64
65extern bool nondeterministic_parser;
66
7b42569e
AD
67
68/*-----------.
69| --report. |
70`-----------*/
71
e8a0acd6 72enum report
ec3bc396 73 {
273a74fa
AD
74 report_none = 0,
75 report_states = 1 << 0,
76 report_itemsets = 1 << 1,
742e4900 77 report_lookahead_tokens = 1 << 2,
b408954b 78 report_solved_conflicts = 1 << 3,
273a74fa 79 report_all = ~0
ec3bc396 80 };
b8a41559 81/** What appears in the *.output file. */
ec3bc396
AD
82extern int report_flag;
83
7b42569e
AD
84/*----------.
85| --trace. |
86`----------*/
b8a41559
AD
87enum trace
88 {
89 trace_none = 0, /**< No traces. */
90 trace_scan = 1 << 0, /**< Grammar scanner traces. */
91 trace_parse = 1 << 1, /**< Grammar parser traces. */
92 trace_resource = 1 << 2, /**< Memory allocation. */
93 trace_sets = 1 << 3, /**< Grammar sets: firsts, nullable etc. */
94 trace_bitsets = 1 << 4, /**< Use of bitsets. */
95 trace_tools = 1 << 5, /**< m4 invocation. */
96 trace_automaton = 1 << 6, /**< Construction of the automaton. */
97 trace_grammar = 1 << 7, /**< Reading, reducing the grammar. */
98 trace_time = 1 << 8, /**< Time consumption. */
99 trace_skeleton = 1 << 9, /**< Skeleton postprocessing. */
100 trace_m4 = 1 << 10, /**< M4 traces. */
101 trace_all = ~0 /**< All of the above. */
102 };
103/** What debug items bison displays during its run. */
104extern int trace_flag;
105
7b42569e
AD
106/*-------------.
107| --warnings. |
108`-------------*/
109
110enum warnings
111 {
112 warnings_none = 0, /**< Issue no warnings. */
113 warnings_error = 1 << 0, /**< Warnings are treated as errors. */
114 warnings_yacc = 1 << 1, /**< POSIXME. */
115 warnings_all = ~0 /**< All of the above. */
116 };
117/** What warnings are issued. */
118extern int warnings_flag;
119
120
121/** Process the command line arguments.
122 *
123 * \param argc size of \a argv
124 * \param argv list of arguments.
125 */
d33cb3ae 126void getargs (int argc, char *argv[]);
b2ca4022
AD
127
128#endif /* !GETARGS_H_ */