我目前正在使用 bison 和 flex 作为标记器开发 verilog 解析器。我的语法工作正常,现在我的目标是将收集到的数据存储在数据库中。
(如果您不知道 verilog 是什么,这并不重要,但您可以在此处找到信息:http://www.verilog.com/VerilogBNF.html)
我目前坚持获取 token 值。我的语法主要由字符串和一些数字组成。
我浏览了互联网并找到了一些有用的东西,这些东西引导我编写这种 lex 规则:
[A-Za-z_]+[A-Za-z0-9_$]* {
lline = yylineno;yylval.str = strdup(yytext);
return K_IDENTIFIER;
}
在我的野牛输入文件 .y 中,我做了一些调整
#define YYSTYPE char*
....
%union {char* str;
double val;
}
%token<str>K_IDENTIFIER
...
beginning of the grammar rules
现在,当我有一个包含 K_IDENTIFIER 的语法规则时,例如
module : K_MODULE K_IDENTIFIER list_of_ports_parameters K_POINTVIRG
{cout << "the value of K_IDENTIFIER is :"<< $2.str << endl;}
list_of_module_itemsE
K_ENDMODULE
fdsfds
如您所见,我想打印 K_IDENTIFIER 的值(它是一个字符串)。这只是帮助我理解背后机制的一个例子,因为稍后我将创建一些 C++ 对象并根据我阅读的内容在其中填充信息。
如果您需要更多代码来查看我的问题,请随时提问。
谢谢你
最佳答案
与 %union
, #define
为 YYSTYPE
没有必要;这可能是问题的一部分。 Bison 会自动选择合适的工会成员,因此您只需要 $2
引用该值,而不是 $2.str
, IE。:
{ cout << "the value of K_IDENTIFIER is: " << $2 << endl; }
关于Bison/Flex 解析器获取字符串作为标记值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5819098/