- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试跟踪所有函数的签名,以便检查 - 当所有输入文件都已扫描时 - 是否所有函数都已定义,否则报告错误。为此,我希望扫描器将 END_OF_FILE
标记返回给解析器,以便调用我的检查过程,但我收到“标记未定义”错误,尽管我将其定义为标记解析器。
有什么建议吗?
最佳答案
发送您自己的文件结束标记很少是个好主意,如果您选择这样做,则需要格外小心。
幸运的是,几乎从来没有必要这样做。
如果你想在解析结束之前执行代码,你可以在开始生产时这样做:
start: program { /* Code to execute at the end of the parse */ }
;
如果您使用的是 bison,请注意:代码将在解析完成时执行,无论它是否成功完成。特别是,输入流中可能仍有未使用的 token 。 [注1]
在很多情况下,这不是问题。错误将立即被检测到(除非操作调用 YYACCEPT
)并且即使解析失败通常也不会出现额外检查。在某些应用程序中,您甚至可能想要这种行为;例如,如果您正在解析嵌入在较大文本中的表达式,并且不想坚持将解析的上下文扩展到文本的末尾。
但是如果你真的需要知道解析是否完成,检查yychar
的值是YYEOF
就足够了(见bison manual了解详细信息。)因此您可以将之前的替换为:
start: program { if (yychar == YYEOF) {
/* Code to execute at the end of the parse */
}
else {
/* There is definitely an error. Probably do nothing. */
}
}
如果您要发送自己的文件结束 token ,您需要确保仍然维护解析器和词法扫描器之间的契约,即:
虽然词法扫描器有时可以处理违反第二个条件的情况,但这是未定义的行为,在某些情况下生成的扫描器会出现段错误或执行其他不良操作。由于解析器不会将您的自定义文件结束标记理解为输入结束,因此它会在收到它后继续请求更多标记。
这意味着您确实需要同时发送您的 token 和正确的 END
token ,这意味着执行如下操作:
%%
/* This code is inserted at the top of yylex */
static int eof_reached = 0; /* Note: not reentrant */
if (eof_reached) return END;
/* ... */
<<EOF>> { eof_reached = 1; return MY_END_OF_FILE; }
这会起作用,但正如所写,扫描器只能使用一次,因为无法重置 eof_reached bool 值。您可以使它成为一个全局的,或者您可以构建一个可重入扫描器并将其添加到扫描器上下文对象的额外数据部分。这些都是在调用 yylex 之间维护扫描器状态的有用技术,但在这种特殊情况下,我认为使用它们不会获得任何好处,因为如上所述,几乎永远不需要发送自定义输入结束 token 。
至于您遇到的具体问题:
没有更多细节,无法回复:
I get a "token undefined" error,
来自什么? Bison ?柔性?编译器?消息到底说了什么?它指的是你的代码的哪一行? (你是否准确地调用了文件结束标记 END_OF_FILE
?)
关于bison - 在输入文件中到达 EOF 时如何做某事?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42713823/
我有一个使用 Yacc 编写的语法。语法的相关部分摘录在这里 postfix : primary | postfix '[' expr ']' | postfix '[' ex
如何在 bison/yacc 中使用继承的属性? 说,我有这样的语法 - 程序 -> stmts 我想做的是在 Bison 身上: 程序:stmts {$$.next = newLabel(); $1
有什么方法可以更改 Bison 错误消息的格式?例如,不要说 syntax error, unexpected T_ID, expected ';' or T_IMPORT说 unexpected i
我的语法有这两个标记声明: %token RP %token ELSE 而这两条规则: Statement : IF LP Exp RP Statement; Statement : IF LP
如果有一个表单的输入文件: BEGIN stuff.... END BEGIN stuff ... END 我的 .y 文件是这样的 %token BEGIN %token END %star
我希望为现有语言创建一个 JavaScript 解析器,该语言目前具有笨拙的“手工制作”C# 和 Java 解析器。我想使用 Jison,并且也一直在尝试学习 Bison 的基础知识。 我不确定如何回
目前我正在研究一个源到源编译器,我已经编写了一个野牛解析器,可以正确地为输入创建 AST。我现在需要对语法树进行多次转换,因此我需要向树中插入许多节点。 我可以手动创建所有要添加到语法树中的结构体/联
如果有一个表单的输入文件: BEGIN stuff.... END BEGIN stuff ... END 我的 .y 文件是这样的 %token BEGIN %token END %star
我正在寻找为现有语言创建 JavaScript 解析器的方法,该语言目前具有笨拙的“手工制作”C# 和 Java 解析器。想用Jison,也在努力学习Bison的基础。 一个我不确定如何回答的问题是
我正在使用 flex/bison 编写解析器(我可以用 Python 编写解析器,但我总是更喜欢经典。) 当我用这个编译代码时: gcc -lfl -ly chance.tab.c lex.yy.c
正在使用 flex/bison 开发编译器。我的构建输出中有此警告。 警告:在默认操作中键入冲突 ('s' '') 请问有什么帮助吗? 最佳答案 它似乎与源中的 %token 和 %type 声明有关
考虑这个 lex.l 文件: %{ #include "y.tab.h" %} digit [0-9] letter [a-zA-Z] %% "+"
我正在为 bison 中的一个简单的 Pascal 编译器编写语法,我想可视化我在 pascal.y 中指定的语法的解析树。是否可以基于我的 pascal.y 文件以图形方式显示语法树? 最佳答案 野
我正在尝试编写一个能够使用以下输入的语法: begin #this is a example x = 56; while x > 0 do begin point 15
我正在尝试使用 BNF 语法编写 Flex/Bison 文件。但是,当我尝试编译时出现错误,而且我不确定如何调试它们。 BNF语法: ::= | head() ::=:: | @ | tail() |
我正在用 Flex/Bison 编写一个小程序来标记/解析我创建的查询语言。 我想知道是否有任何方法可以在 Flex/Bison 中创建任何关键字。 我的意思是:flex 将输入分解成一个标记列表,但
我正在尝试使用 flex 和 bison 创建过滤器,因为我想从复杂的语言中获取某些语法元素。我的计划是使用 flex + bison 来识别语法,并转储出感兴趣元素的位置。 (然后使用脚本根据转储的
我正在尝试实现一个可以进行浮点运算的 Flex/bison 计算器。我的 Flex 代码如下所示 %{ #include "calc.tab.h" #include void yyerror(cha
我正在尝试使用 FLEX 和 BISON 进行一些练习。 这是我写的代码: calc_pol.y %{ #define YYSTYPE double #include "calc_pol.tab.h"
我有一个使用括号和方括号作为分隔符的语法。当由 bison 生成的解析器输入带有不平衡分隔符的输入时,传递给 yyerror 的 YYLTYPE* 中的错误位置是输入的结尾。所以,例如,在输入 x
我是一名优秀的程序员,十分优秀!