123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360 |
- .TH BISON 1 local
- .SH NAME
- bison A2.2 \- GNU Project parser generator (yacc replacement)
- .SH SYNOPSIS
- .B bison
- [
- .BI \-b " file-prefix"
- ] [
- .BI \-\-file-prefix= file-prefix
- ] [
- .B \-d
- ] [
- .B \-\-defines
- ] [
- .B \-k
- ] [
- .B \-\-token-table
- ] [
- .B \-l
- ] [
- .B \-\-no-lines
- ] [
- .B \-n
- ] [
- .B \-\-no-parser
- ] [
- .BI \-o " outfile"
- ] [
- .BI \-\-output-file= outfile
- ] [
- .BI \-p " prefix"
- ] [
- .BI \-\-name-prefix= prefix
- ] [
- .B \-r
- ] [
- .B \-\-raw
- ] [
- .B \-t
- ] [
- .B \-\-debug
- ] [
- .B \-v
- ] [
- .B \-\-verbose
- ] [
- .B \-V
- ] [
- .B \-\-version
- ] [
- .B \-y
- ] [
- .B \-\-yacc
- ] [
- .B \-h
- ] [
- .B \-\-help
- ] [
- .B \-\-fixed-output-files
- ]
- file
- .SH DESCRIPTION
- .I Bison
- is a parser generator in the style of
- .IR yacc (1).
- It should be upwardly compatible with input files designed
- for
- .IR yacc .
- .PP
- Input files should follow the
- .I yacc
- convention of ending in
- .BR .y .
- Unlike
- .IR yacc ,
- the generated files do not have fixed names, but instead use the prefix
- of the input file.
- For instance, a grammar description file named
- .B parse.y
- would produce the generated parser in a file named
- .BR parse.tab.c ,
- instead of
- .IR yacc 's
- .BR y.tab.c .
- .PP
- This description of the options that can be given to
- .I bison
- is adapted from the node
- .B Invocation
- in the
- .B bison.texinfo
- manual, which should be taken as authoritative.
- .PP
- .I Bison
- supports both traditional single-letter options and mnemonic long
- option names. Long option names are indicated with
- .B \-\-
- instead of
- .BR \- .
- Abbreviations for option names are allowed as long as they
- are unique. When a long option takes an argument, like
- .BR \-\-file-prefix ,
- connect the option name and the argument with
- .BR = .
- .SS OPTIONS
- .TP
- .BI \-b " file-prefix"
- .br
- .ns
- .TP
- .BI \-\-file-prefix= file-prefix
- Specify a prefix to use for all
- .I bison
- output file names. The names are
- chosen as if the input file were named
- \fIfile-prefix\fB.c\fR.
- .TP
- .B \-d
- .br
- .ns
- .TP
- .B \-\-defines
- Write an extra output file containing macro definitions for the token
- type names defined in the grammar and the semantic value type
- .BR YYSTYPE ,
- as well as a few
- .B extern
- variable declarations.
- .sp
- If the parser output file is named
- \fIname\fB.c\fR
- then this file
- is named
- \fIname\fB.h\fR.
- .sp
- This output file is essential if you wish to put the definition of
- .B yylex
- in a separate source file, because
- .B yylex
- needs to be able to refer to token type codes and the variable
- .BR yylval .
- .TP
- .B \-r
- .br
- .ns
- .TP
- .B \-\-raw
- The token numbers in the \fIname\fB.h\fR file are usually the Yacc compatible
- translations. If this switch is specified, Bison token numbers
- are output instead. (Yacc numbers start at 257 except for single character
- tokens; Bison assigns token numbers sequentially for all tokens
- starting at 3.)
- .TP
- .B \-k
- .br
- .ns
- .TP
- .B \-\-token-table
- This switch causes the \fIname\fB.tab.c\fR output to include a list of
- token names in order by their token numbers; this is defined in the array
- .IR yytname .
- Also generated
- are #defines for
- .IR YYNTOKENS ,
- .IR YYNNTS ,
- .IR YYNRULES ,
- and
- .IR YYNSTATES .
- .TP
- .B \-l
- .br
- .ns
- .TP
- .B \-\-no-lines
- Don't put any
- .B #line
- preprocessor commands in the parser file.
- Ordinarily
- .I bison
- puts them in the parser file so that the C compiler
- and debuggers will associate errors with your source file, the
- grammar file. This option causes them to associate errors with the
- parser file, treating it an independent source file in its own right.
- .TP
- .B \-n
- .br
- .ns
- .TP
- .B \-\-no-parser
- Do not generate the parser code into the output; generate only
- declarations. The generated \fIname\fB.tab.c\fR file will have only
- constant declarations. In addition, a \fIname\fB.act\fR file is
- generated containing a switch statement body containing all the
- translated actions.
- .TP
- .BI \-o " outfile"
- .br
- .ns
- .TP
- .BI \-\-output-file= outfile
- Specify the name
- .I outfile
- for the parser file.
- .sp
- The other output files' names are constructed from
- .I outfile
- as described under the
- .B \-v
- and
- .B \-d
- switches.
- .TP
- .BI \-p " prefix"
- .br
- .ns
- .TP
- .BI \-\-name-prefix= prefix
- Rename the external symbols used in the parser so that they start with
- .I prefix
- instead of
- .BR yy .
- The precise list of symbols renamed is
- .BR yyparse ,
- .BR yylex ,
- .BR yyerror ,
- .BR yylval ,
- .BR yychar ,
- and
- .BR yydebug .
- .sp
- For example, if you use
- .BR "\-p c" ,
- the names become
- .BR cparse ,
- .BR clex ,
- and so on.
- .TP
- .B \-t
- .br
- .ns
- .TP
- .B \-\-debug
- Output a definition of the macro
- .B YYDEBUG
- into the parser file,
- so that the debugging facilities are compiled.
- .TP
- .B \-v
- .br
- .ns
- .TP
- .B \-\-verbose
- Write an extra output file containing verbose descriptions of the
- parser states and what is done for each type of look-ahead token in
- that state.
- .sp
- This file also describes all the conflicts, both those resolved by
- operator precedence and the unresolved ones.
- .sp
- The file's name is made by removing
- .B .tab.c
- or
- .B .c
- from the parser output file name, and adding
- .B .output
- instead.
- .sp
- Therefore, if the input file is
- .BR foo.y ,
- then the parser file is called
- .B foo.tab.c
- by default. As a consequence, the verbose
- output file is called
- .BR foo.output .
- .TP
- .B \-V
- .br
- .ns
- .TP
- .B \-\-version
- Print the version number of
- .I bison
- and exit.
- .TP
- .B \-h
- .br
- .ns
- .B \-\-help
- Print a summary of the options to
- .I bison
- and exit.
- .TP
- .B \-y
- .br
- .ns
- .TP
- .B \-\-yacc
- .br
- .ns
- .TP
- .B \-\-fixed-output-files
- Equivalent to
- .BR "\-o y.tab.c" ;
- the parser output file is called
- .BR y.tab.c ,
- and the other outputs are called
- .B y.output
- and
- .BR y.tab.h .
- The purpose of this switch is to imitate
- .IR yacc 's
- output file name conventions.
- Thus, the following shell script can substitute for
- .IR yacc :
- .sp
- .RS
- .ft B
- bison \-y $*
- .ft R
- .sp
- .RE
- .PP
- The long-named options can be introduced with `+' as well as `\-\-',
- for compatibility with previous releases. Eventually support for `+'
- will be removed, because it is incompatible with the POSIX.2 standard.
- .SH FILES
- /usr/local/lib/bison.simple simple parser
- .br
- /usr/local/lib/bison.hairy complicated parser
- .SH SEE ALSO
- .IR yacc (1)
- .br
- The
- .IR "Bison Reference Manual" ,
- included as the file
- .B bison.texinfo
- in the
- .I bison
- source distribution.
- .SH DIAGNOSTICS
- Self explanatory.
- .SH AUTHOR
- Bison A2.2 is adapted from Bison-1.22 by
- .in +1i
- Wilfred J. Hansen (wjh+@cmu.edu),
- Andrew Consortium, Carnegie Mellon University
- .in -1i
- The newer version differs in that
- .in .5i
- Errors in the grammar will not stop the reader; all errors are
- found in one pass. A complete example and test case is
- the file mess.y in the distribution.
- .sp
- Tokens may now be specified as multiple-character strings:
- "<=" can appear where formerly would have to be LESSEQ.
- .sp
- The -n switch produces the parser tables without including
- the parser; a project can now use its own parser
- and avoid the GNU license for the resulting application.
|