gpt4 book ai didi

c# - ANTLR AST 建筑 : root node as string instead of character

转载 作者:行者123 更新时间:2023-11-30 22:43:19 26 4
gpt4 key购买 nike

我可能会问一个愚蠢/基本的问题,但我对 ANTLR AST 构建感到困惑。

我想做的是一种 bool 表达式解析器,这样在父节点上我有运算符及其操作数作为子节点。比如一句话

( ( A B C & D ) | ( E & ( F | G ) ) )

理想情况下应该代表

              |
/ \
/ \
/ \
/ \
& &
/ \ / \
/ \ / \
/ D E |
/|\ / \
A B C / \
F G

来自以下语法。

grammar Test;

options
{
language = 'Java';
output=AST;
}


exp : word (expRest^)? | '('! exp ')'! (expRest^)? ;

expRest : (('&'|'|'|'!'|'&!'|'|!')^) exp | (('~'^) digit+ exp);
word : letter letter* -> ^(letter letter*);
letter : '0'|'1'|'2'|'3'|'4'|'5'|'6'|'7'|'8'|'9'|'a'|'b'|'c'|'d'|'e'|'f'|'g'|'h'|'i'|'j'|'k'|'l'|'m'|'n'|'o'|'p'|'q'|'r'|'s'|'t'|'u'|'v'|'w'|'x'|'y'|'z'|'A'|'B'|'C'|'D'|'E'|'F'|'G'|'H'|'I'|'J'|'K'|'L'|'M'|'N'|'O'|'P'|'Q'|'R'|'S'|'T'|'U'|'V'|'W'|'X'|'Y'|'Z';
digit : '0'|'1'|'2'|'3'|'4'|'5'|'6'|'7'|'8'|'9';

问题是,我得到的“A B C”是作为“&”的子节点的列表(数组)。

是否可以将其限制为单个字符串???即“A B C”或者换句话说,是否可以在 AST 的根节点处有多个字符???如果是,我该如何实现?

作为引用,我想制作一个“风险因素和当前经济状况”的语法树

P.S. 我也试过了:

word    :   (letter letter*)^ ;

仅供引用,我使用的是 .NET 环境。

最佳答案

您可以在您的语法中插入虚构标记,这些标记将成为单词“组”的词根。我不认为将 ABC 粘合在一起是个好主意,因为您可能需要将它们分开,对吧?

我无法真正弄清楚您到底想做什么,所以这里有一个小演示,您可以(尝试)了解一下:

grammar BoolExp;

options {
output=AST;
}

tokens {
MultiWord;
}

parse
: booleanExp EOF!
;

booleanExp
: orExp
;

orExp
: andExp ('|'^ andExp)*
;

andExp
: notExp ('&'^ notExp)*
;

notExp
: '!'^ atom
| atom
;

atom
: '(' booleanExp ')' -> booleanExp
| WORD WORD+ -> ^(MultiWord WORD+)
| WORD
;

WORD
: ('a'..'z' | 'A'..'Z')+
;

SPACE
: (' ' | '\t' | '\r' | '\n'){skip();}
;

如果你从它生成一个解析器并用输入测试它:

( ( A B C & D ) | ( E & ( F | G ) ) )

您将获得以下 AST:

alt text

我没有发布生成用于创建上面 AST 图像的 DOT 文件的 (Java) 测试类,因为您说您正在使用 .NET 目标。如果您确实想看一下,请发表评论,我也会发布。

关于c# - ANTLR AST 建筑 : root node as string instead of character,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4015194/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com