假设我有一个简单的 JavaCC 语法来解析加法和减法:
....
void CompilationUnit() :
{}
{
(Expression())+
EOF
}
void Expression() :
{}
{
Number()
(
Addition()
| Subtraction()
)*
}
void Number() :
{}
{
}
void Addition() :
{}
{
Number()
}
void Subtraction() :
{}
{
Number()
}
我有使用此语法生成的 AST 来计算结果的类:
public class Calculator extends DepthFirstVisitor {
int result = -1;
public void visit(Expression n) {
if (result >= 0) System.out.println(toText(n) + " = " + result);
result = 0;
super.visit(n);
}
public void visit(Number n) {
...
}
public void visit(Addition n) {
...
}
....
}
我能够计算表达式的值,但我也需要原始表达式(就像它出现的那样)。所以对于以下输入:
5 + 2 - 1 2 + 1
我想要以下输出:
5 + 2 - 1 = 6 2 + 1 = 3
不幸的是,因为我跳过了空格或换行符之类的字符,所以我得到的是:
5+2-1 = 6 2+1 = 3
有什么办法可以输出原始文本(包括跳过的字符)?
请注意,实际问题要大得多,语法要复杂得多。所以我并不是真的在寻找针对上述问题的解决方案(例如预处理行并将它们拆分为换行符或修改方法以“手动”在每个标记后添加空格),但更像是使用一些 JavaCC 功能的解决方案.