假设我有一个简单的语法(词法分析器和解析器),用于解析和评估简单的数学表达式(如在一些 antlr 示例中),它还允许简单的变量定义(即分配浮点值)和使用这些变量。例如可以处理以下情况:
r = 2.5;
PI = 3.14;
PI * r * r;
这应该用于更复杂的语法。事实上,有几个不同的。问题是上述 contains 的词法分析器基本上将每个字符串识别为标记类型 ID,即潜在的变量名称,但更复杂的语法可能包含其他关键字。
如果我做
lexer grammar ComplexLexer;
import SimpleMathExprLexer;
// ...
IF : 'if'|'IF';
THEN : 'then'|'THEN';
// ...
那么 ID 已经与这些关键字匹配并不是很有帮助。简单地将 import 语句移到这些规则之下是行不通的。有没有办法解决这个问题,或者当我看构图时我完全走错了路?