我目前正在使用bison和flex作为标记器来处理verilog解析器.我的语法工作正常,现在我的目标是将收集的数据存储在数据库中.(如果你不知道verilog是什么,它并不重要,但你可以在这里找到信息:http://www.verilog.com/VerilogBNF.html)
我目前停留在获取令牌值.我的语法主要由字符串和一些数字组成.
我浏览了互联网并找到有用的东西,引导我写这种lex规则:
[A-Za-z_]+[A-Za-z0-9_$]* {
lline = yylineno;yylval.str = strdup(yytext);
return K_IDENTIFIER;
}
Run Code Online (Sandbox Code Playgroud)
在我的野牛输入文件中.我做了一些调整
#define YYSTYPE char*
....
%union {char* str;
double val;
}
%token<str>K_IDENTIFIER
...
beginning of the grammar rules
Run Code Online (Sandbox Code Playgroud)
现在,当我有一个语法规则,其中有一个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
Run Code Online (Sandbox Code Playgroud)
fdsfds
如您所见,我想打印K_IDENTIFIER的值(这是一个字符串).这只是一个例子来帮助我理解背后的机制,因为稍后我会根据我读到的内容创建一些c ++对象并在其中填充信息.
如果您需要更多代码来查看我的问题,请随时提出.谢谢
随着%union中,#define对于YYSTYPE没有必要; 这可能是问题的一部分.Bison将自动选择合适的联盟成员,因此您只需要$2引用该值,而不是$2.str:
{ cout << "the value of K_IDENTIFIER is: " << $2 << endl; }
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3377 次 |
| 最近记录: |