我目前正在思考如何最好地使用Antlr生成AST并将其转换为有用的对象,我可以在我的程序中使用它.
我的语法(除了学习)的目的是创建一个可执行(运行时解释)语言.
例如,我如何获取属性子树并实例化特定的Attribute类.例如.
我的语言中的以下代码:
Print(message:"Hello *")
会产生以下AST:
alt text http://img36.imageshack.us/img36/1672/simpleast.png
我目前的想法是工厂类可以读取树,提取名称(消息)和键入(STRING)值(“Hello *”).现在,知道类型我可以实例化正确的类(例如一个StringAttribute类)并传入所需的属性数据 – 名称和值.
可以将相同的方法用于定义工厂,拉出定义名称(Print),实例化Print类,然后传入属性工厂生成的属性.
对于更复杂的程序,事情会变得更复杂:
Program(args:[1,2,3,4,5])
{
If(isTrue:IsInArray(array:{Program.args} value:5))
{
Then {
Print(message:"5 is in the array")
} Else {
Print(message:"More complex " + "message")
}
}
}
alt text http://img205.imageshack.us/img205/3452/complexast.png
任何/所有的帮助或想法都非常受欢迎.非常感谢.
以前的相关问题(可能有用):
> How do I make a tree
parser
> Solving LL recursion problem
> Antrl3 conditional tree rewrites
解决方法:
我建议阅读Terence Parr撰写的第7章“建立高级口译员”.
编辑
好的,为了让你度过那本书等待的时间,这就是你(至少)需要的东西:
>全球记忆空间;
>函数空间(每个函数空间也有一个(本地)内存空间);
和脑中浮现的课程(UML-ish风格):
>类翻译
> global:MemorySpace
>功能:堆栈<功能>
> ……
>类MemorySpace
> vars:Map< String,Object>
> ……
>类功能
> local:MemorySpace
> execute():void
> ……