2012-05-02 100 views
1

我有一个ANTLR语法问题,我只是没有看到我的问题,一直想弄明白一个多小时。我剥我的问题到这个简单的语法:ANTLR语法问题

 grammar TestGrammar; 

     options { 
      language = Java; 
      k=2; 
     } 

     compu_method : '/begin COMPU_METHOD' NAME NAME NAME NAME 
       (
       (formula) 
       |('COEFFS' realnumber realnumber realnumber realnumber realnumber realnumber) 
      )* 
       '/end COMPU_METHOD'; 

      formula : '/begin FORMULA' (.)* '/end FORMULA'; 

      realnumber: (INT | FLOAT); 

     NAME : LETTER (LETTER|'0'..'9'|'['|']'|'.')* ; 
     fragment LETTER : 'A'..'Z' | 'a'..'z' | '_' ; 

     INT : MINUS? ('0' | '1'..'9' '0'..'9'*) ; 
     FLOAT : MINUS? ('0'..'9')+ '.' ('0'..'9')* Exponent? | MINUS? '.' ('0'..'9')+ Exponent? | MINUS? ('0'..'9')+ Exponent ; 
     MINUS : '-' ; 
     fragment Exponent : ('e'|'E') ('+'|'-')? ('0'..'9')+ ; 

     WS : ('\r\n'|'\n'|' '|'\r'|'\t'|'\u000C') { $channel=HIDDEN;}; 

,我试图以匹配输入是:

/begin COMPU_METHOD 
     foo 
     foo 
     foo 
     foo 
     COEFFS 0.000000 1.000000 0.000000 0.000000 0.000000 1.000000 
/end COMPU_METHOD 

口译总是给我“不匹配输入‘COEFFS’期待‘\ u0005’ “

但是为什么?

如果我在语法中改变(公式)和('COEFFS'...)的顺序,那很好,我只是不明白为什么?

回答

1

修复错误之后(在compu_method中有一个无效的N标记,并且您在formula规则后忘记了一个分号),我没有任何问题解析输入。我碰到下面的分析树:

enter image description here

请注意,我使用的调试,而不是解释(这是越野车)。所以你的问题可能是你使用了解释器。

+0

我该如何使用调试器而不是解释器? – metacircle

+0

假设你正在使用ANTLRWorks:按下“CTRL + D”。如果你使用Eclipse的ANTLR插件(它使用ANTLRWorks,AFAIK的解释器和调试器组件):我不知道。 –