grammar RCFAE rule num [0-9]+ <Num> end rule IDentifIEr [a-zA-Z] [a-zA-Z]* <ID> endend
我正在尝试解析简单的字符串(“A”和“5”).如果我把该规则放在第一位,则“5”被识别为Num,如果我将该规则放在第二位,则返回nil.类似地,如果我将该规则放在第一位,则“A”被识别为ID,则返回nil.我无法理解这两个规则如何以任何方式重叠.这让我疯狂!
关于树梢或正则表达式,我是否缺少或不理解?在此先感谢您的帮助.
解决方法 Treetop预计第一条规则将成为“主要规则”.它不会尝试应用您定义的所有规则,直到匹配为止 – 它仅应用主规则,如果不匹配,则失败.要执行您想要的 *** 作,您需要添加一个可能是num或标识符的主规则,如下所示:
grammar RCFAE rule Expression num / IDentifIEr end rule num [0-9]+ <Num> end rule IDentifIEr [a-zA-Z] [a-zA-Z]* <ID> endend总结
以上是内存溢出为你收集整理的ruby – 树梢上最简单的规则不起作用全部内容,希望文章能够帮你解决ruby – 树梢上最简单的规则不起作用所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)