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


Python SymbolTable.get_return_present方法代码示例

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


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

示例1: TypeChecker

# 需要导入模块: from SymbolTable import SymbolTable [as 别名]
# 或者: from SymbolTable.SymbolTable import get_return_present [as 别名]

#.........这里部分代码省略.........
                    elif function_ret_type == 'float' and ret_type == 'int':
                        pass
                    elif ret_type != function_ret_type:
                        print("Error: Improper returned type, expected %s, got %s: line %s" %
                              (function_ret_type, ret_type, node.lineno))
            else:
                # should not happen...
                print("something bad happened while parsing or checking")
        else:
            print("Error: return instruction outside a function: line %s" % node.lineno)

    def visit_ContinueInstr(self, node):
        if not self.symbol_table.is_inside_loop():
            print("Error: continue instruction outside a loop: line %s" % node.lineno)

    def visit_BreakInstr(self, node):
        if not self.symbol_table.is_inside_loop():
            print("Error: break instruction outside a loop: line %s" % node.lineno)

    def visit_CompoundInstr(self, node):
        self.symbol_table = self.symbol_table.push_scope("CompoundInstr")
        for item in node.declarations:
            self.visit(item)
        for item in node.instructions:
            self.visit(item)
        self.symbol_table = self.symbol_table.pop_scope()

    def visit_BinaryExpr(self, node):
        type_1 = self.get_return_type(node.left)
        if not type_1:
            print("Error: Usage of undeclared variable '%s': line %s" % (self.visit(node.left), node.lineno))
        type_2 = self.get_return_type(node.right)
        if not type_2:
            print("Error: Usage of undeclared variable '%s': line %s" % (self.visit(node.right), node.lineno))
        op = self.visit(node.op)
        ret = self.ttypes[op][type_1][type_2]
        if not ret:
            print("Error: Illegal operation, %s %s %s: line %s" % (type_1, op, type_2, node.left.lineno))
        return ret

    def visit_MethodCallExpr(self, node):
        name = self.visit(node.name)
        fun_def = self.symbol_table.get(name)
        if fun_def:
            if len(fun_def.args) != len(node.args):
                print("Error: Improper number of args in %s call: line %s" % (fun_def.name.name, node.lineno))
            else:
                for (fun_arg, call_arg) in zip(fun_def.args, node.args):
                    fun_arg_type = fun_arg.arg_type.name
                    call_arg_type = self.get_return_type(call_arg)
                    if fun_arg_type and call_arg_type:
                        if fun_arg_type == 'int' and call_arg_type == 'float':
                            print("Warning: Possible loss of precision: passing %s instead of %s: line %s" %
                                  (call_arg_type, fun_arg_type, node.lineno))
                        elif fun_arg_type == 'float' and call_arg_type == 'int':
                            pass
                        elif call_arg_type != fun_arg_type:
                            print("Error: Improper type of args in %s call: line %s" % (name, node.lineno))
                            break
            return fun_def.type.name
        else:
            print("Error: Call of undefined function: '%s': line %s" % (name, node.lineno))

    def visit_FunctionDef(self, node):
        name = self.visit(node.name)
        if self.symbol_table.get(name):
            print("Error: Redefinition of function '%s': line %s" % (name, node.lineno))
        self.symbol_table.put(name, FunctionDefSymbol(node.name, node.return_type, node.args))
        self.symbol_table = self.symbol_table.push_scope("FunctionDef")
        self.symbol_table.put(name, FunctionDefSymbol(node.name, node.return_type, node.args))
        self.symbol_table.function_name = name
        for arg in node.args:
            self.visit(arg)
        self.symbol_table.set_return_present(0)
        self.visit(node.body)
        if not self.symbol_table.get_return_present():
            print("Error: Missing return statement in function '%s' returning %s: line %s" %
                  (name, self.visit(node.return_type), node.lineno))
        self.symbol_table = self.symbol_table.pop_scope()

    def visit_Argument(self, node):
        name = self.visit(node.name)
        if self.symbol_table.name == "FunctionDef":
            self.symbol_table.put(name, VariableSymbol(node.name, node.arg_type))

    def get_return_type(self, node):
        if isinstance(node, AST.Name):
            var = self.symbol_table.get(node.name)
            return None if not var else var.type.name
        return self.visit(node)

    @staticmethod
    def check_type_consistency(node, declared_type, expression_ret_type):
        if declared_type == 'int' and expression_ret_type == 'float':
            print("Warning: Possible loss of precision: assignment of %s to %s: line %s" %
                  (expression_ret_type, declared_type, node.lineno))
        elif declared_type == 'float' and expression_ret_type == 'int':
            pass
        elif declared_type != expression_ret_type:
            print("Error: Assignment of %s to %s: line %s" % (expression_ret_type, declared_type, node.lineno))
开发者ID:margg,项目名称:tk,代码行数:104,代码来源:TypeChecker.py


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