Я пытаюсь создать простой переводчик, переводящий что-то вроде:
aaa | bbb | ccc
до
1 : aaa
2 : bbb
c : ccc
Вот грамматика test01.g:
grammar test01;
options {
output=AST;
}
@members{
int N;
}
test
@init{
N = 0;
}:
id ('|' id)* -> id (BR id)*;
id : {N++;} ID -> {new CommonTree(new CommonToken(ID, Integer.toString(N) + " : " + $ID.text))};
ID : ('a'..'z')+;
BR : '\n';
WS : ' '{$channel=HIDDEN;};
Источник перевода FooTest.java:
import org.antlr.runtime.*;
class FooTest {
public static void main(String[] args) throws Exception {
String text = "aaa | bbb | ccc";
System.out.println("parsing: "+text);
ANTLRStringStream in = new ANTLRStringStream(text);
test01Lexer lexer = new test01Lexer(in);
CommonTokenStream tokens = new TokenRewriteStream(lexer);
test01Parser parser = new test01Parser(tokens);
parser.test();
System.out.println("Result: "+tokens.toString());
}
}
Когда я запускаю его, я ожидаю получить что-то вроде:
parsing: aaa | bbb | ccc
Result:
1 : aaa
2 : bbb
3 : ccc
Но я получаю:
parsing: aaa | bbb | ccc
Result: aaa | bbb | ccc
Текст кажется неизменным.
Как получить модифицированный источник?