YACC输出什么?

时间:2012-11-14 20:26:37

标签: compiler-construction yacc lex

我有一个下面列出的lex程序,它识别(词法分析)特定的令牌,并在从键盘输入时将它们输出到屏幕。我想使用yacc进行下面代码的语法分析,但我不太明白这个部分.....输出会是什么样子?我的代码是否足够?我在网上看过很多关于yacc的文章....只需要有人给出一个简单的解释。提前谢谢......

/* Regular Definitions */
RelationalOp_1         "<"
RelationalOp_2      "<="
RelationalOp_3      "=<"    
RelationalOp_4      "=="
RelationalOp_5      "!="
RelationalOp_6      ">"
RelationalOp_7      ">="
RelationalOp_8      "=>"

%%

{RelationalOp_1}        {printf("(RelationalOp_1, %s)\n", yytext);}
{RelationalOp_2}        {printf("(RelationalOp_2, %s)\n", yytext);}
{RelationalOp_3}        {printf("(RelationalOp_3, %s)\n", yytext);}
{RelationalOp_4}        {printf("(RelationalOp_4, %s)\n", yytext);}
{RelationalOp_5}        {printf("(RelationalOp_5, %s)\n", yytext);}
{RelationalOp_6}        {printf("(RelationalOp_6, %s)\n", yytext);}
{RelationalOp_7}        {printf("(RelationalOp_7, %s)\n", yytext);}
{RelationalOp_8}        {printf("(RelationalOp_8, %s)\n", yytext);}

.                            printf("Invalid input: %s\n",yytext);

%%

main()
{
  yylex();
}

yywrap()
{
}

1 个答案:

答案 0 :(得分:0)

对您的问题的简短回答是否定的,使用yacc生成的解析器,您所拥有的内容是不完整的。在lex生成的扫描程序中,您希望在内存中为解析器提供令牌,而不是简单地将某些内容写入控制台。

为了理解上下文,Pete Jinks's lecture notes是全面的,并展示了lex和yacc生成的程序如何协同工作。您还可以查看Bison的在线手册,它是yacc的GNU版本。