*nix Documentation Project
·  Home
 +   man pages
·  Linux HOWTOs
·  FreeBSD Tips
·  *niX Forums

  man pages->FreeBSD man pages -> yacc (1)              
Title
Content
Arch
Section
 

YACC(1)

Contents


NAME    [Toc]    [Back]

     yacc -- an LALR(1) parser generator

SYNOPSIS    [Toc]    [Back]

     yacc [-dlrtv] [-b file_prefix] [-o output_filename] [-p symbol_prefix]
	  filename

DESCRIPTION    [Toc]    [Back]

     The yacc utility reads the grammar specification in the file filename and
     generates an LR(1) parser for it.	The parsers consist of a set of
     LALR(1) parsing tables and a driver routine written in the C programming
     language.	The yacc utility normally writes the parse tables and the
     driver routine to the file y.tab.c.

     The following options are available:

     -b file_prefix
	     Change the prefix prepended to the output file names to the
	     string denoted by file_prefix.  The default prefix is the character
 y.

     -d      Cause the header file y.tab.h to be written.

     -l      If the -l option is not specified, yacc will insert #line directives
 in the generated code.  The #line directives let the C compiler
 relate errors in the generated code to the user's original
	     code.  If the -l option is specified, yacc will not insert the
	     #line directives.	Any #line directives specified by the user
	     will be retained.

     -o output_filename
	     Cause yacc to write the generated code to output_filename instead
	     of the default file, y.tab.c.

     -p symbol_prefix
	     Change the prefix prepended to yacc-generated symbols to the
	     string denoted by symbol_prefix.  The default prefix is the
	     string yy.

     -r      Cause yacc to produce separate files for code and tables.	The
	     code file is named y.code.c, and the tables file is named
	     y.tab.c.

     -t      Change the preprocessor directives generated by yacc so that
	     debugging statements will be incorporated in the compiled code.

     -v      Cause a human-readable description of the generated parser to be
	     written to the file y.output.

ENVIRONMENT    [Toc]    [Back]

     TMPDIR  Name of directory where temporary files are to be created.

TABLES    [Toc]    [Back]

     The names of the tables generated by this version of yacc are yylhs,
     yylen, yydefred, yydgoto, yysindex, yyrindex, yygindex, yytable, and
     yycheck.  Two additional tables, yyname and yyrule, are created if
     YYDEBUG is defined and non-zero.

FILES    [Toc]    [Back]

     y.code.c
     y.tab.c
     y.tab.h
     y.output
     /tmp/yacc.aXXXXXXXXXX
     /tmp/yacc.tXXXXXXXXXX
     /tmp/yacc.uXXXXXXXXXX

DIAGNOSTICS    [Toc]    [Back]

     If there are rules that are never reduced, the number of such rules is
     reported on standard error.  If there are any LALR(1) conflicts, the number
 of conflicts is reported on standard error.

SEE ALSO    [Toc]    [Back]

      
      
     yyfix(1)

HISTORY    [Toc]    [Back]

     A yacc command appeared in PWB UNIX.

STANDARDS    [Toc]    [Back]

     The yacc utility conforms to IEEE Std 1003.2 (``POSIX.2'').


FreeBSD 5.2.1			 May 24, 1993			 FreeBSD 5.2.1
[ Back ]
 Similar pages
Name OS Title
bison Linux GNU Project parser generator (yacc replacement)
bison IRIX GNU Project parser generator (yacc replacement)
escap_print_fields Tru64 parser routines for
escap_size_data Tru64 parser routines for
escap_parse_fields Tru64 parser routines for
escap_copy_fields Tru64 parser routines for
escap_cmp_fields Tru64 parser routines for
libbsdxml FreeBSD eXpat XML parser library
CDaddcallback IRIX set a callback for the CD audio data parser
DTresetparser IRIX resets a DAT audio data parser
Copyright © 2004-2005 DeniX Solutions SRL
newsletter delivery service