识别Treetop语法中的Ruby代码

前端之家收集整理的这篇文章主要介绍了识别Treetop语法中的Ruby代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用 Treetop来解析ERB文件.我需要能够处理如下行:
<% ruby_code_here %>
<%= other_ruby_code %>

由于Treetop是用Ruby编写的,你用Ruby编写Treetop语法,Treetop中已经有一些现有方法可以说“嘿,在这里查找Ruby代码,并给我分解”,而不必编写单独的规则来处理Ruby语言的所有部分?我正在寻找一种方法,在我的.treetop语法文件中,有类似的东西:

rule erb_tag
  "<%" ruby_code "%>" {
    def content
      ...
    end
  }
end

其中ruby_code由Treetop提供的某些规则处理.

编辑:someone else使用Ruby-lex解析ERB,但是我试图重现他所做的错误.在生成解析器类时,rlex程序没有生成完整的类.

编辑:对,所以你很多都很郁闷,但感谢你的信息. :)对于我的Master的项目,我正在编写一个测试用例生成器,需要使用ERB作为输入.幸运的是,出于我的目的,我只需要识别ERB代码中的一些内容,例如if语句和其他条件以及循环.我想我可以提出Treetop语法来匹配它,但需要注意的是Ruby并不完整.

解决方法

据我所知,还没有人为Ruby创建Treetop语法. (事实上​​,除了MRI和YARV附带的YACC语法之外,没有人能够为Ruby创建任何语法.)我知道Treetop的作者已经开发了几年,但这并不是一项微不足道的事情. .获得XRuby中使用的ANTLR语法大约花了5年时间,它仍然不完全符合.

Ruby的语法是疯狂的,令人难以置信的复杂.

猜你在找的Ruby相关文章