YACC
Section: User Commands (1)
Updated: July 15, 1990
Index
NAME
Yacc - 一个生成 LALR(1) 文法分析器的程序
SYNOPSIS 总览
yacc [ -dlrtv ] [ -b
file_prefix
] [ -p
symbol_prefix
]
filename
DESCRIPTION 描述
Yacc 从 filename 所指定的文件中读出文法(grammar)定义,并为之生成
一个 LR(1) 分析器。分析器是由一系列 LALR(1)分析表和用 C 语言写的
驱动例程组成。通常把分析表和驱动例程写到文件 y.tab.c 中。
译注:余在翻译有关编译原理的东西时,总是区别语法(Syntax)和文法
(grammar)。驱动例程指的是自动生成的 yyparse 函数和相关函数的源代
码。Yacc和 Lex 自动生成的常量、变量、结构,函数等的名称通常以 yy
为前缀,目的是不与用户自己的 C 程序定义的名称冲突。LALR(1)文法的
分析是通过在堆栈上通过移进(shift)和归约(reduce)实现的,任何经过良
好设计的语言(例如 Lisp,C,Perl,C++,Java),用LALR(1)实现起来是容易,
高效和可靠的。
可得到下面的参数:
-
- -b file_prefix
-
-b 选项改变的是为输出的文件名准备的前缀,这个字符串用 file_prefix
指定,缺省的前缀是 y.。
- -d
-
-d
-d 选项导致多写一个 y.tab.h 头文件。(包含一些词法定义)
- -l
-
如果没有指定 -l 选项,则 yacc 将在生成的代码中插入 #line 宏命令
(directive)。 #line 宏命令用于让 C 编译器把在生成的 C 代码中的
错误与用户的原始 yacc 代码联系起来。如果指定了 -l 选项,yacc 将
不插入 #line 宏命令。用户指定的 #line 宏命令还是将被保留的。
- -p symbol_prefix
-
-p 选项改变的是为 Yacc生成的符号(symbols)准备的前缀,这个字符串用
symbol_prefix 指定,缺省的前缀是 yy。
- -r
-
-r 选项导致 yacc 生成生成分开的代码和表文件。代码文件名是 y.code.c,
表文件名是 y.tab.c。
- -t
-
-t 选项更改 Yacc 生成的预处理宏命令,这样调试语句就会被结合到编译后的
代码中。
- -v
-
-v 选项导致在文件 y.output 中写出可被人阅读的对生成的分析器的描述。
如果设置了环境变量TMPDIR,TMPDIR 所指定的字符串将被用作生成临时文件
的路径名。
FILES 相关文件
y.code.c
y.tab.c
y.tab.h
y.output
/tmp/yacc.aXXXXXX
/tmp/yacc.tXXXXXX
/tmp/yacc.uXXXXXX
DIAGNOSTICS 诊断
如果有些规则永不归约,在标准错误输出上报告这些规则的数目。
如果有任何 LALR(1) 冲突,在标准错误输出上报告这些冲突的数目。
译注:规则永不归约通常出现在文法有二义性规则的时候,术语叫
归约-归约冲突。LALR(1) 冲突术语上叫移进-归约冲突,解决的方法
一种是 Lisp 风格的语言的括号总动员,一种是 C 风格的语言的优先
级排座次,还有一种是结构化的解决方法例如 Fortran77 的IF...ENDIF
及 Algol68 的if...fi。C 风格语言的一个标志就是至少有一个
从 Algol60 至今死不改悔的移进-归约冲突--都是else(悬挂)惹的祸。
只要你清楚并让用户知道,有移进-归约冲突可以是正常的,不象
归约-归约冲突那样必须避免。
[中文版维护人]
mhss
推荐:
编译原理及实践/(美)Kenneth C. Louden著. -北京: 机械工业出版社,
2000.3 ¥39。
实践出真知,无有捷径。读 byacc 的源程序是艰苦的事情, 但能澄清
一些似是而非的认识, 亲历编程的精真妙明的境界, 虽无大的实际利益,
毕竟是聊胜于无。在娑婆世界中, 一个完整的美梦是十分珍贵的。
仁者, 何妨一试。
推荐:
编译原理/吕映芝等著. -北京: 清华大学出版社,1998.1 ¥21。
余见到 LL(2) 感到很欣慰。余以为是改进消除左递归和提取左因子的
算法就可以解决的事情,故不应是学术问题。余不懂学术,若妄言之,
大人有大量,请海涵了。
[中文版最新更新]
2000/11/13
《中国Linux论坛man手册页翻译计划》:
http://cmpp.linuxforum.net
Index
- NAME
-
- SYNOPSIS 总览
-
- DESCRIPTION 描述
-
- FILES 相关文件
-
- DIAGNOSTICS 诊断
-
- [中文版维护人]
-
- [中文版最新更新]
-
- 《中国Linux论坛man手册页翻译计划》:
-
This document was created by
man2html,
using the manual pages.
Time: GMT, January 14, 2004