- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
仍在使用 Antlr,我正在搜索在文档中找不到的内容。
这是一个可以检测字符串中“非”模式的解析器:
factor : 'not'^ primary| primary;
(and some other lines).
但是如果我想在我的 primary 之后检测一个表达式怎么办?例如
B exists
如何定义一个解析器规则来搜索我的表达式的其余部分?我通过类比尝试了这个,但直到现在都无法让它发挥作用。
exists : primary 'exists'^ | primary;
根据我在表达式中放置 exists 的位置,我得到了
line 1:44 extraneous input 'exists' expecting ')'
或
line 1:3 mismatched input 'exists' expecting ')'
line 1:22 missing EOF at ')'
错误
谢谢!
编辑:
除了一件事,我的语法和你的完全一样。这是我的代码:
// Aiming at parsing a complete BQS formed Query
grammar Logic;
options {
backtrack=true;
output=AST;
}
/*------------------------------------------------------------------
* PARSER RULES
*------------------------------------------------------------------*/
parse
: expression EOF -> expression
; // ommit the EOF token
expression
: query
;
query
: term (OR^ term)* // make `or` the root
;
term
: factor (AND^ factor)*
;
factor
: NOT^ primary
| primary
;
primary // this one has to be completed (a lot)
: atom (LIKE^ atom)* // right expressions have to be indicated
| atom (EXISTS^)?
;
atom
: ID
| '('! expression ')'! // omit both ( and )
;
/*------------------------------------------------------------------
* LEXER RULES
*------------------------------------------------------------------*/
// GENERAL OPERATORS:
NOTLIKE : 'notlike'; // whitespaces have been removed
LIKE : 'like';
EXISTS : 'exists';
OR : 'or';
AND : 'and';
NOT : 'not';
//ELEMENTS
ID : (CHARACTER)+;
WHITESPACE : ( '\t' | ' ' | '\r' | '\n'| '\u000C' )+ { $channel = HIDDEN; } ;
那么问题显然就出在这里了。
我这里有一个严重的问题。一旦删除了所有 or 和 not 之后,我希望我的主要形式为:
A like B
或
A exists
我的代码有什么问题?我认为这正是我的主要规则所说的?
我真的很想找到一种调试自己的方法,因为:
line 1:3 mismatched input 'like' expecting ')'
真的不是 self 解释
非常感谢您的帮助,我真的很难理解 antlr 文档网站 :s。
最佳答案
我怀疑您在其中一个解析器规则中放错了 EOF
。您发布的规则似乎没有太大问题:至少,不会导致您发布的错误。
对于(可能的) future 问题(不仅是 ANTLR 问题),我强烈建议您发布一个“自包含”的语法(或示例代码)。换句话说:你发布了一个语法,别人可以很容易地在他们自己的机器上运行,而不需要修改它(!),这样他们就能看到你所看到的。现在它只是在猜测你的其他规则是什么样子的。
以下内容:
exists
: atom (Exists^)?
;
就像一个魅力,你可以测试自己:
grammar T;
options {
output=AST;
}
parse
: expr EOF -> expr
;
expr
: orexp
;
orexp
: andexp (Or^ andexp)*
;
andexp
: not (And^ not)*
;
not
: Not^ exists
| exists
;
exists
: atom (Exists^)?
;
atom
: Num
| Id
| '(' expr ')' -> expr
;
Or : 'or';
And : 'and';
Exists : 'exists';
Not : 'not';
Num : '0'..'9'+;
Id : ('a'..'z'|'A'..'Z'|'_') ('a'..'z'|'A'..'Z'|'0'..'9'|'_')*;
Space : ' ' {skip();};
输入:
(A or B) and (not C or D exists) or not E exists
产生以下 AST:
您的主要
规则的备选方案 1 和备选方案 2:
primary
: atom (LIKE^ atom)* // alternative 1
| atom (EXISTS^)? // alternative 2
;
匹配单个atom
。这是解析器无法正确解析您的输入的原因(并且需要您添加 backtrack=true;
,这应该避免!)。
我没有测试它,但我很确定如果你从选项 block 中删除 backtrack=true;
并重写 primary
如下:
primary
: atom ( (LIKE^ atom)* // alternative 1
| EXISTS^ // alternative 2
)
;
现在备选方案 1 仅匹配单个 atom
,并且没有歧义(至少,that 规则中没有)。
关于java - 如果在我的表达之后需要词法分析器怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10518905/
我试图了解传递给 setTimeout 的箭头函数如何记住上一个执行上下文中的 this 的值。我知道在执行箭头函数时会使用词法作用域规则查找 this 值。这是否意味着箭头函数关闭变量和 this
这个问题已经有答案了: How does the "this" keyword in Javascript act within an object literal? [duplicate] (4 个
我已阅读 this问题,我想我已经理解了投票最多的答案,但他说 since basically every programming language in wide use today uses le
如何让这段宏发挥预期的作用? -- 我想从词法环境中捕获 p 而不必将其作为参数发送给宏。 (define-syntax-rule (fi a b) (if p a b)) ;--->capt
Program A() { x, y, z: integer; procedure B() { y: integer; y=0;
我正在用 Java 实现自己的链表。节点类只有一个名为“name”的字符串字段和一个名为“link”的节点。现在我有一个测试驱动程序类,它只按顺序插入几个名字。现在,我正在尝试编写一种排序方法来按字母
考虑到这个question SO,其中调用了整个 C# 内存中编译器。只有lexical and syntactic analyzing时是必需的:将文本解析为词素流,检查它们并退出。 在System
我有 2 个场景。 这失败了: class F { public X X { get; set; } } 错误 CS0102:类型“F” ' 已经包含 ' X 的定义| ' 这个有效: class
我有一个用 NodeJS 执行的 .js 文件。这是我的文件的内容: var ctry = "America"; function outer(msg) { console.log(msg +
我对编写汇编程序的概念非常陌生,即使在阅读了大量 Material 之后,我仍然很难理解几个概念。 将源文件实际分解为 token 的过程是什么?我相信这个过程称为词法分析,我已经到处搜索有意义的真实
在 static scoping,标识符可以通过分析/解析源代码来确定(与动态作用域不同,动态作用域或多或少需要了解调用者环境)。 我的问题是这样的,因为静态作用域只需要解析源代码以了解作用域和标识符
编辑:我在第一个答案后更改了示例代码,因为我想出了一个简单的版本来回避相同的问题。 我目前正在学习 Common Lisp 的作用域属性。在我认为我有一个坚实的理解之后,我决定编写一些我可以预测结果的
考虑这段代码: class Bar(object): pass class Foo(object): def bar(self): return Bar() f = Foo() def Bar
将 ES6 箭头函数与词法 this 绑定(bind)结合使用非常棒。 但是,我刚才在使用典型的 jQuery 单击绑定(bind)时遇到了一个问题: class Game { foo() {
将 ES6 箭头函数与词法 this 绑定(bind)结合使用非常好。 但是,我刚才在将它与典型的 jQuery 点击绑定(bind)一起使用时遇到了一个问题: class Game { foo(
我是一名优秀的程序员,十分优秀!