2
我想創建簡單的翻譯翻譯是這樣的:ANTLR如何獲取重寫的代碼源? (使用TokenRewriteStream)
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());
}
}
當我運行它,我excpect得到的東西,如:
parsing: aaa | bbb | ccc
Result:
1 : aaa
2 : bbb
3 : ccc
,但我得到:
parsing: aaa | bbb | ccc
Result: aaa | bbb | ccc
文字似乎是不變。
如何獲取修改後的源代碼?