python – 如何更改规则的解析顺序?

python – 如何更改规则的解析顺序?,第1张

概述I’m developing a programming language,我在处理条件陈述时遇到了麻烦.这是我的语言代码: x = 4 ->? 2 > 5 <? x = 7 -> ?> ->[o] <- x -> 这是定义条件语句的语法的特定部分: post_condition_evaluation_block : post_condition_evaluation_block_o I’m developing a programming language,我在处理条件陈述时遇到了麻烦.这是我的语言代码:

x = 4 ->? 2 > 5 <?    x = 7 -> ?> ->[o] <- x ->

这是定义条件语句的语法的特定部分:

post_condition_evaluation_block : post_condition_evaluation_block_opening_operator compound_statement post_condition_evaluation_block_closing_operatorcondition_statement : condition_specification_operator Expression post_condition_evaluation_block                    | condition_specification_operator Expression post_condition_evaluation_block condition_extension

语法没有任何问题,代码正常运行.问题是表达式2> 5在以下语句x = 7之后被评估,因此打印的是7而不是4(这是错误的,因为表达式的计算结果为false).我正在处理这个计算条件块的问题:

condition_blocks = {0: True}current_condition_block = 0

然后说到条件声明:

def p_condition_statement(p):    """condition_statement : condition_specification_operator Expression post_condition_evaluation_block                           | condition_specification_operator Expression post_condition_evaluation_block condition_extension"""    global current_condition_block    current_condition_block += 1    condition_blocks[current_condition_block] = p[2]    print(condition_blocks)

它将表达式的False(p2)值添加到字典中的相应块索引.问题是,当我完成任务时:

def p_assignment(p):    """assignment : IDentifIEr assignment_operator Expression"""    if len(p) == 4 and condition_blocks[current_condition_block]:        if p[2] == '=':            IDentifIErs[p[1]] = parse_object(p[3])        elif p[2] == "+=":            IDentifIErs[p[1]] += parse_object(p[3])        elif p[2] == "-=":            IDentifIErs[p[1]] -= parse_object(p[3])        elif p[2] == "*=":            IDentifIErs[p[1]] *= parse_object(p[3])        elif p[2] == "/=":            IDentifIErs[p[1]] /= parse_object(p[3])        p[0] = (p[1],p[2],p[3])

获得评估的块是默认的“块外范围”块.分配规则在表达式之前被解析/处理,这在我的脑海中没有意义,因为整个代码应该从头到尾处理.

我显然不是解析/ YACC的专家,这是我的第一次尝试,我发现完全没有提示要做什么in the docs.我不知道如何停止解析器,跳过解析器,更改解析顺序..也许问题在于我的语法,但我看不出如何更改解析顺序.

解决方法 当生产减少时 – 也就是说,执行其语义动作 – 所有引用的非终端都已经减少了.换句话说,孩子总是在父母面前减少,这就是为什么yacc被称为自下而上的解析器.

实现更大灵活性的唯一实用方法是在解析期间构建AST,然后通过在AST上进行树形行程来评估(或者其他)完整表达式.然后,您可以按照任何合适的顺序自由地走完整棵树.

总结

以上是内存溢出为你收集整理的python – 如何更改规则的解析顺序?全部内容,希望文章能够帮你解决python – 如何更改规则的解析顺序?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1197693.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存