我所用到的yacc与lex命令

来源:互联网 发布:mac电脑恢复出厂设置 编辑:程序博客网 时间:2024/05/16 10:25

最近上操作系统实验课,用到了yacc和lex,Linux下使用bison和flex。下面是我用到的一些功能和命令,与大家分享。

在yacc或bison里定义的token如 %token xxx等,如果要在flex里用到,那么要用命令生成相应的头文件。

使用命令:

yacc -d example.y

生成y.tab.h,y.tab.c。

或者使用命令:

bison -d example.y
生成example.tab.h,example.tab.c。

头文件里有token的枚举定义给flex使用,所以要在flex源文件 example.l 中的第一部分包含这个头文件:

1 %{2 #include "example.tab.h"3 //其他4 %}

或者

1 %{2 #include "y.tab.h"3 //其他4 %}
使用命令:

flex example.l

  生成文件 lex.yy.c,这样词法分析器就在lex.yy.c里,语法分析器就在y.tab.c或者example.tab.c里了。
  然后,lex.yy.c,y.tab.c(或example.tab.c),y.tab.h(或example.tab.h)这三个文件与其他文件一起编译链接就可以了。

使用命令:

yacc -v example.y

  生成y.output,这个文件包含了LR分析表以及移进归约冲突。
使用命令:

bison -v example.y

生成example.output,这个文件包含了LR分析表以及移进归约冲突。


在需要用到语法分析的地方调用 yyparse() 函数即可。通常词法分析会从标准输入读取,(即yyin = stdin),但可以在调用yyparse()之前把输入改成一个指定的文件:yyin = file(file是FILE指针);

//其他代码yyin = file;  //file是FILE指针yyparse();//其他代码

除了从标准输入和文件读取外,bison还可以从一个已有的字符串中读取进行分析,注意这个字符串要以'\0'终止:

1 //其他代码2 //string为以'\0'终止的字符数组3 yy_scan_string(string);4 yyparse();5 //其他代码