0

我有这样的声明:

=MYFUNCTION_NAME(1,2,3)

我的语法是:

grammar Expression;
options
{  
    language=CSharp3;
    output=AST;
    backtrack=true;
} 
tokens 
{
  FUNC;
  PARAMS;
}
@parser::namespace { Expression }
@lexer::namespace  { Expression }

public 
parse     :   ('=' func )*;
func      :  funcId  '(' formalPar* ')' -> ^(FUNC funcId formalPar);
formalPar :  (par ',')* par  -> ^(PARAMS par+);
par       :  INT;
funcId    :  complexId+ ('_'? complexId+)*;
complexId  
  : ID+
  | ID+DIGIT+      ;
ID        :  ('a'..'z'|'A'..'Z'|'а'..'я'|'А'..'Я')+;
DIGIT     : ('0'..'9')+;
INT       : '-'? ('0'..'9')+;

在树上我得到:

        [**FUNC**]
             |
 [MYFUNCTION] [_] [NAME] [**PARAMS**]

为什么解析器将函数的名称拆分为 3 个节点:“MYFUNCTION、“_”、“NAME”?我该如何解决?

4

1 回答 1

0

除法始终基于令牌执行。由于ID标记不能包含_字符,因此结果是 3 个单独的标记,稍后由funcId语法规则处理。要为您的函数名称创建单个节点,您需要创建一个词法分析器规则,该规则可以将输入MYFUNCTION_NAME作为单个标记进行匹配。

于 2013-10-02T14:59:41.233 回答