]>
git.saurik.com Git - bison.git/blob - src/getargs.c
1 /* Parse command line arguments for Bison.
3 Copyright (C) 1984, 1986, 1989, 1992, 2000, 2001, 2002, 2003, 2004,
4 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
6 This file is part of Bison, the GNU Compiler Compiler.
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.
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.
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/>. */
26 #include <c-strcase.h>
27 #include <configmake.h>
31 /* Hack to get <getopt.h> to declare getopt with a prototype. */
32 #if lint && ! defined __GNU_LIBRARY__
33 # define __GNU_LIBRARY__
34 # define HACK_FOR___GNU_LIBRARY___PROTOTYPE 1
39 #ifdef HACK_FOR___GNU_LIBRARY___PROTOTYPE
40 # undef __GNU_LIBRARY__
41 # undef HACK_FOR___GNU_LIBRARY___PROTOTYPE
47 #include "muscle_tab.h"
56 bool token_table_flag
;
57 bool yacc_flag
; /* for -y */
59 bool error_verbose
= false;
61 bool nondeterministic_parser
= false;
62 bool glr_parser
= false;
64 int report_flag
= report_none
;
65 int trace_flag
= trace_none
;
66 int warnings_flag
= warnings_none
;
68 static struct bison_language
const valid_languages
[] = {
69 { "c", "c-skel.m4", ".c", ".h", true },
70 { "c++", "c++-skel.m4", ".cc", ".hh", true },
71 { "java", "java-skel.m4", ".java", ".java", false },
72 { "", "", "", "", false }
75 int skeleton_prio
= default_prio
;
76 const char *skeleton
= NULL
;
77 int language_prio
= default_prio
;
78 struct bison_language
const *language
= &valid_languages
[0];
79 const char *include
= NULL
;
84 /** Decode an option's set of keys.
86 * \param option option being decoded.
87 * \param keys array of valid subarguments.
88 * \param values array of corresponding (int) values.
89 * \param flags the flags to update
90 * \param args comma separated list of effective subarguments to decode.
91 * If 0, then activate all the flags.
93 * If VALUE != 0 then KEY sets flags and no-KEY clears them.
94 * If VALUE == 0 then KEY clears all flags and no-KEY sets all flags.
95 * Thus no-none = all and no-all = none.
98 flags_argmatch (const char *option
,
99 const char * const keys
[], const int values
[],
100 int *flags
, char *args
)
104 args
= strtok (args
, ",");
107 int no
= strncmp (args
, "no-", 3) == 0 ? 3 : 0;
108 int value
= XARGMATCH (option
, args
+ no
, keys
, values
);
119 args
= strtok (NULL
, ",");
126 /** Decode a set of sub arguments.
128 * \param FlagName the flag familly to update.
129 * \param Args the effective sub arguments to decode.
131 * \arg FlagName_args the list of keys.
132 * \arg FlagName_types the list of values.
133 * \arg FlagName_flag the flag to update.
135 #define FLAGS_ARGMATCH(FlagName, Args) \
136 flags_argmatch ("--" #FlagName, FlagName ## _args, FlagName ## _types, \
137 &FlagName ## _flag, Args)
140 /*----------------------.
141 | --report's handling. |
142 `----------------------*/
144 static const char * const report_args
[] =
146 /* In a series of synonyms, present the most meaningful first, so
147 that argmatch_valid be more readable. */
150 "itemset", "itemsets",
151 "lookahead", "lookaheads", "look-ahead",
157 static const int report_types
[] =
160 report_states
, report_states
,
161 report_states
| report_itemsets
, report_states
| report_itemsets
,
162 report_states
| report_lookahead_tokens
,
163 report_states
| report_lookahead_tokens
,
164 report_states
| report_lookahead_tokens
,
165 report_states
| report_solved_conflicts
,
169 ARGMATCH_VERIFY (report_args
, report_types
);
172 /*---------------------.
173 | --trace's handling. |
174 `---------------------*/
176 static const char * const trace_args
[] =
178 /* In a series of synonyms, present the most meaningful first, so
179 that argmatch_valid be more readable. */
181 "scan - grammar scanner traces",
182 "parse - grammar parser traces",
183 "automaton - construction of the automaton",
184 "bitsets - use of bitsets",
185 "grammar - reading, reducing the grammar",
186 "resource - memory consumption (where available)",
187 "sets - grammar sets: firsts, nullable etc.",
188 "muscles - m4 definitions passed to the skeleton",
189 "tools - m4 invocation",
191 "skeleton - skeleton postprocessing",
192 "time - time consumption",
193 "all - all of the above",
197 static const int trace_types
[] =
215 ARGMATCH_VERIFY (trace_args
, trace_types
);
218 /*------------------------.
219 | --warnings's handling. |
220 `------------------------*/
222 static const char * const warnings_args
[] =
224 /* In a series of synonyms, present the most meaningful first, so
225 that argmatch_valid be more readable. */
226 "none - no warnings",
227 "midrule-values - unset or unused midrule values",
228 "yacc - incompatibilities with POSIX YACC",
229 "all - all of the above",
230 "error - warnings are errors",
234 static const int warnings_types
[] =
237 warnings_midrule_values
,
243 ARGMATCH_VERIFY (warnings_args
, warnings_types
);
246 /*-------------------------------------------.
247 | Display the help message and exit STATUS. |
248 `-------------------------------------------*/
250 static void usage (int) ATTRIBUTE_NORETURN
;
256 fprintf (stderr
, _("Try `%s --help' for more information.\n"),
260 /* For ../build-aux/cross-options.pl to work, use the format:
261 ^ -S, --long[=ARGS] (whitespace)
262 A --long option is required.
263 Otherwise, add exceptions to ../build-aux/cross-options.pl. */
265 printf (_("Usage: %s [OPTION]... FILE\n"), program_name
);
267 Generate LALR(1) and GLR parsers.\n\
272 Mandatory arguments to long options are mandatory for short options too.\n\
275 The same is true for optional arguments.\n\
281 -h, --help display this help and exit\n\
282 -V, --version output version information and exit\n\
283 --print-localedir output directory containing locale-dependent data\n\
284 --print-datadir output directory containing skeletons and XSLT\n\
285 -y, --yacc emulate POSIX Yacc\n\
286 -W, --warnings[=CATEGORY] report the warnings falling in CATEGORY\n\
292 -L, --language=LANGUAGE specify the output programming language\n\
293 (this is an experimental feature)\n\
294 -S, --skeleton=FILE specify the skeleton to use\n\
295 -t, --debug instrument the parser for debugging\n\
296 --locations enable location support\n\
297 -D, --define=NAME[=VALUE] same as `%define NAME \"VALUE\"'\n\
298 -p, --name-prefix=PREFIX prepend PREFIX to the external symbols\n\
299 -l, --no-lines don't generate `#line' directives\n\
300 -k, --token-table include a table of token names\n\
304 /* Keep -d and --defines separate so that ../build-aux/cross-options.pl
305 * won't assume that -d also takes an argument. */
308 --defines[=FILE] also produce a header file\n\
309 -d likewise but cannot specify FILE (for POSIX Yacc)\n\
310 -r, --report=THINGS also produce details on the automaton\n\
311 --report-file=FILE write report to FILE\n\
312 -v, --verbose same as `--report=state'\n\
313 -b, --file-prefix=PREFIX specify a PREFIX for output files\n\
314 -o, --output=FILE leave output to FILE\n\
315 -g, --graph[=FILE] also output a graph of the automaton\n\
316 -x, --xml[=FILE] also output an XML report of the automaton\n\
317 (the XML schema is experimental)\n\
322 Warning categories include:\n\
323 `midrule-values' unset or unused midrule values\n\
324 `yacc' incompatibilities with POSIX YACC\n\
325 `all' all the warnings\n\
326 `no-CATEGORY' turn off warnings in CATEGORY\n\
327 `none' turn off all the warnings\n\
328 `error' treat warnings as errors\n\
333 THINGS is a list of comma separated words that can include:\n\
334 `state' describe the states\n\
335 `itemset' complete the core item sets with their closure\n\
336 `lookahead' explicitly associate lookahead tokens to items\n\
337 `solved' describe shift/reduce conflicts solving\n\
338 `all' include all the above information\n\
339 `none' disable the report\n\
342 printf (_("\nReport bugs to <%s>.\n"), PACKAGE_BUGREPORT
);
349 /*------------------------------.
350 | Display the version message. |
351 `------------------------------*/
356 /* Some efforts were made to ease the translators' task, please
358 printf (_("bison (GNU Bison) %s"), VERSION
);
360 fputs (_("Written by Robert Corbett and Richard Stallman.\n"), stdout
);
364 _("Copyright (C) %d Free Software Foundation, Inc.\n"),
365 PACKAGE_COPYRIGHT_YEAR
);
368 This is free software; see the source for copying conditions. There is NO\n\
369 warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n\
375 /*-------------------------------------.
376 | --skeleton and --language handling. |
377 `--------------------------------------*/
380 skeleton_arg (char const *arg
, int prio
, location loc
)
382 if (prio
< skeleton_prio
)
384 skeleton_prio
= prio
;
387 else if (prio
== skeleton_prio
)
390 _("multiple skeleton declarations are invalid");
391 complain_at (loc
, msg
);
396 language_argmatch (char const *arg
, int prio
, location loc
)
400 if (prio
< language_prio
)
403 for (i
= 0; valid_languages
[i
].language
[0]; i
++)
404 if (c_strcasecmp (arg
, valid_languages
[i
].language
) == 0)
406 language_prio
= prio
;
407 language
= &valid_languages
[i
];
410 msg
= _("invalid language `%s'");
412 else if (language_prio
== prio
)
413 msg
= _("multiple language declarations are invalid");
417 complain_at (loc
, msg
, arg
);
420 /*----------------------.
421 | Process the options. |
422 `----------------------*/
425 Should be computed from long_options. */
426 static char const short_options
[] =
450 /* Values for long options that do not have single-letter equivalents. */
453 LOCATIONS_OPTION
= CHAR_MAX
+ 1,
454 PRINT_LOCALEDIR_OPTION
,
455 PRINT_DATADIR_OPTION
,
459 static struct option
const long_options
[] =
461 /* Operation modes. */
462 { "help", no_argument
, 0, 'h' },
463 { "version", no_argument
, 0, 'V' },
464 { "print-localedir", no_argument
, 0, PRINT_LOCALEDIR_OPTION
},
465 { "print-datadir", no_argument
, 0, PRINT_DATADIR_OPTION
},
466 { "warnings", optional_argument
, 0, 'W' },
469 { "name-prefix", required_argument
, 0, 'p' },
470 { "include", required_argument
, 0, 'I' },
473 { "file-prefix", required_argument
, 0, 'b' },
474 { "output", required_argument
, 0, 'o' },
475 { "output-file", required_argument
, 0, 'o' },
476 { "graph", optional_argument
, 0, 'g' },
477 { "xml", optional_argument
, 0, 'x' },
478 { "report", required_argument
, 0, 'r' },
479 { "report-file", required_argument
, 0, REPORT_FILE_OPTION
},
480 { "verbose", no_argument
, 0, 'v' },
483 { "trace", optional_argument
, 0, 'T' },
486 { "defines", optional_argument
, 0, 'd' },
488 /* Operation modes. */
489 { "fixed-output-files", no_argument
, 0, 'y' },
490 { "yacc", no_argument
, 0, 'y' },
493 { "debug", no_argument
, 0, 't' },
494 { "define", required_argument
, 0, 'D' },
495 { "locations", no_argument
, 0, LOCATIONS_OPTION
},
496 { "no-lines", no_argument
, 0, 'l' },
497 { "raw", no_argument
, 0, 0 },
498 { "skeleton", required_argument
, 0, 'S' },
499 { "language", required_argument
, 0, 'L' },
500 { "token-table", no_argument
, 0, 'k' },
505 /* Under DOS, there is no difference on the case. This can be
506 troublesome when looking for `.tab' etc. */
508 # define AS_FILE_NAME(File) (strlwr (File), (File))
510 # define AS_FILE_NAME(File) (File)
513 /* Build a location for the current command line argument. */
516 command_line_location (void)
519 /* "<command line>" is used in GCC's messages about -D. */
520 boundary_set (&res
.start
, uniqstr_new ("<command line>"), optind
, -1);
527 getargs (int argc
, char *argv
[])
531 while ((c
= getopt_long (argc
, argv
, short_options
, long_options
, NULL
))
535 /* ASCII Sorting for short options (i.e., upper case then
536 lower case), and then long-only options. */
539 /* Certain long options cause getopt_long to return 0. */
542 case 'D': /* -DNAME[=VALUE]. */
545 char* value
= strchr (optarg
, '=');
548 muscle_percent_define_insert (name
, command_line_location (),
554 include
= AS_FILE_NAME (optarg
);
558 language_argmatch (optarg
, command_line_prio
,
559 command_line_location ());
563 skeleton_arg (AS_FILE_NAME (optarg
), command_line_prio
,
564 command_line_location ());
568 FLAGS_ARGMATCH (trace
, optarg
);
577 FLAGS_ARGMATCH (warnings
, optarg
);
579 warnings_flag
|= warnings_all
;
583 spec_file_prefix
= AS_FILE_NAME (optarg
);
587 /* Here, the -d and --defines options are differentiated. */
590 spec_defines_file
= xstrdup (AS_FILE_NAME (optarg
));
596 spec_graph_file
= xstrdup (AS_FILE_NAME (optarg
));
600 usage (EXIT_SUCCESS
);
603 token_table_flag
= true;
607 no_lines_flag
= true;
611 spec_outfile
= AS_FILE_NAME (optarg
);
615 spec_name_prefix
= optarg
;
619 FLAGS_ARGMATCH (report
, optarg
);
627 report_flag
|= report_states
;
633 spec_xml_file
= xstrdup (AS_FILE_NAME (optarg
));
640 case LOCATIONS_OPTION
:
641 locations_flag
= true;
644 case PRINT_LOCALEDIR_OPTION
:
645 printf ("%s\n", LOCALEDIR
);
648 case PRINT_DATADIR_OPTION
:
649 printf ("%s\n", compute_pkgdatadir ());
652 case REPORT_FILE_OPTION
:
653 spec_verbose_file
= xstrdup (AS_FILE_NAME (optarg
));
657 usage (EXIT_FAILURE
);
660 if (argc
- optind
!= 1)
662 if (argc
- optind
< 1)
663 error (0, 0, _("missing operand after `%s'"), argv
[argc
- 1]);
665 error (0, 0, _("extra operand `%s'"), argv
[optind
+ 1]);
666 usage (EXIT_FAILURE
);
669 current_file
= grammar_file
= uniqstr_new (argv
[optind
]);
670 MUSCLE_INSERT_C_STRING ("file_name", grammar_file
);