当前位置: 首页>>代码示例>>Python>>正文


Python Grammar.removeLeftRecursion方法代码示例

本文整理汇总了Python中grammar.Grammar.removeLeftRecursion方法的典型用法代码示例。如果您正苦于以下问题:Python Grammar.removeLeftRecursion方法的具体用法?Python Grammar.removeLeftRecursion怎么用?Python Grammar.removeLeftRecursion使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在grammar.Grammar的用法示例。


在下文中一共展示了Grammar.removeLeftRecursion方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: TopDownParser

# 需要导入模块: from grammar import Grammar [as 别名]
# 或者: from grammar.Grammar import removeLeftRecursion [as 别名]
grammar.rules.append(Rule([F], [tNot, F]))
grammar.rules.append(Rule([B], [tEq]))
grammar.rules.append(Rule([B], [tNeq]))
grammar.rules.append(Rule([B], [tLt]))
grammar.rules.append(Rule([B], [tLe]))
grammar.rules.append(Rule([B], [tGt]))
grammar.rules.append(Rule([B], [tGe]))
grammar.rules.append(Rule([Z], [tPl]))
grammar.rules.append(Rule([Z], [tMi]))
grammar.rules.append(Rule([P], [tPl]))
grammar.rules.append(Rule([P], [tMi]))
grammar.rules.append(Rule([P], [tOr]))
grammar.rules.append(Rule([M], [tMu]))
grammar.rules.append(Rule([M], [tDi]))
grammar.rules.append(Rule([M], [tDiv]))
grammar.rules.append(Rule([M], [tMod]))
grammar.rules.append(Rule([M], [tAnd]))

print "grammar:\n", grammar

grammar.removeLeftRecursion()

print "left recursions removed: \n", grammar


expr = [tOpenBr, tIdentifier, tMi, tConst, tCloseBr, tMu, tOpenBr, tIdentifier, tPl, tIdentifier, tCloseBr]
print "expr: %s\n" % ''.join([str(symbol) for symbol in expr])

parser = TopDownParser(grammar)
parser.parse(expr)
开发者ID:arkuzmin,项目名称:compilers,代码行数:32,代码来源:lab3.py


注:本文中的grammar.Grammar.removeLeftRecursion方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。