當前位置: 首頁>>代碼示例>>Python>>正文


Python ExprNodes類代碼示例

本文整理匯總了Python中ExprNodes的典型用法代碼示例。如果您正苦於以下問題:Python ExprNodes類的具體用法?Python ExprNodes怎麽用?Python ExprNodes使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了ExprNodes類的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: visit_ForInStatNode

 def visit_ForInStatNode(self, node):
     # TODO: Remove redundancy with range optimization...
     is_special = False
     sequence = node.iterator.sequence
     if isinstance(sequence, ExprNodes.SimpleCallNode):
         function = sequence.function
         if sequence.self is None and function.is_name:
             if function.name in ('range', 'xrange'):
                 is_special = True
                 for arg in sequence.args[:2]:
                     self.mark_assignment(node.target, arg)
                 if len(sequence.args) > 2:
                     self.mark_assignment(
                         node.target,
                         ExprNodes.binop_node(node.pos,
                                              '+',
                                              sequence.args[0],
                                              sequence.args[2]))
     if not is_special:
         # A for-loop basically translates to subsequent calls to
         # __getitem__(), so using an IndexNode here allows us to
         # naturally infer the base type of pointers, C arrays,
         # Python strings, etc., while correctly falling back to an
         # object type when the base type cannot be handled.
         self.mark_assignment(node.target, ExprNodes.IndexNode(
             node.pos,
             base = sequence,
             index = ExprNodes.IntNode(node.pos, value = '0')))
     self.visitchildren(node)
     return node
開發者ID:Mistobaan,項目名稱:cython,代碼行數:30,代碼來源:TypeInference.py

示例2: visit_ForFromStatNode

    def visit_ForFromStatNode(self, node):
        condition_block = self.flow.nextblock()
        next_block = self.flow.newblock()
        # Condition with iterator
        self.flow.loops.append(LoopDescr(next_block, condition_block))
        self.visit(node.bound1)
        self.visit(node.bound2)
        if node.step is not None:
            self.visit(node.step)
        # Target assignment
        self.flow.nextblock()
        self.mark_assignment(node.target, node.bound1)
        if node.step is not None:
            self.mark_assignment(node.target, ExprNodes.binop_node(node.pos, "+", node.bound1, node.step))
        # Body block
        self.flow.nextblock()
        self.visit(node.body)
        self.flow.loops.pop()
        # Loop it
        if self.flow.block:
            self.flow.block.add_child(condition_block)
        # Else clause
        if node.else_clause:
            self.flow.nextblock(parent=condition_block)
            self.visit(node.else_clause)
            if self.flow.block:
                self.flow.block.add_child(next_block)
        else:
            condition_block.add_child(next_block)

        if next_block.parents:
            self.flow.block = next_block
        else:
            self.flow.block = None
        return node
開發者ID:fatihmert,項目名稱:how-to-cython-mt2,代碼行數:35,代碼來源:FlowControl.py

示例3: visit_ForInStatNode

    def visit_ForInStatNode(self, node):
        # TODO: Remove redundancy with range optimization...
        is_special = False
        sequence = node.iterator.sequence
        target = node.target
        if isinstance(sequence, ExprNodes.SimpleCallNode):
            function = sequence.function
            if sequence.self is None and function.is_name:
                entry = self.current_env().lookup(function.name)
                if not entry or entry.is_builtin:
                    if function.name == "reversed" and len(sequence.args) == 1:
                        sequence = sequence.args[0]
                    elif function.name == "enumerate" and len(sequence.args) == 1:
                        if target.is_sequence_constructor and len(target.args) == 2:
                            iterator = sequence.args[0]
                            if iterator.is_name:
                                iterator_type = iterator.infer_type(self.current_env())
                                if iterator_type.is_builtin_type:
                                    # assume that builtin types have a length within Py_ssize_t
                                    self.mark_assignment(
                                        target.args[0],
                                        ExprNodes.IntNode(
                                            target.pos, value="PY_SSIZE_T_MAX", type=PyrexTypes.c_py_ssize_t_type
                                        ),
                                    )
                                    target = target.args[1]
                                    sequence = sequence.args[0]
        if isinstance(sequence, ExprNodes.SimpleCallNode):
            function = sequence.function
            if sequence.self is None and function.is_name:
                entry = self.current_env().lookup(function.name)
                if not entry or entry.is_builtin:
                    if function.name in ("range", "xrange"):
                        is_special = True
                        for arg in sequence.args[:2]:
                            self.mark_assignment(target, arg)
                        if len(sequence.args) > 2:
                            self.mark_assignment(
                                target, ExprNodes.binop_node(node.pos, "+", sequence.args[0], sequence.args[2])
                            )

        if not is_special:
            # A for-loop basically translates to subsequent calls to
            # __getitem__(), so using an IndexNode here allows us to
            # naturally infer the base type of pointers, C arrays,
            # Python strings, etc., while correctly falling back to an
            # object type when the base type cannot be handled.
            self.mark_assignment(
                target,
                ExprNodes.IndexNode(
                    node.pos,
                    base=sequence,
                    index=ExprNodes.IntNode(target.pos, value="PY_SSIZE_T_MAX", type=PyrexTypes.c_py_ssize_t_type),
                ),
            )

        self.visitchildren(node)
        return node
開發者ID:B-Rich,項目名稱:cython,代碼行數:58,代碼來源:TypeInference.py

示例4: visit_ForFromStatNode

 def visit_ForFromStatNode(self, node):
     self.mark_assignment(node.target, node.bound1)
     if node.step is not None:
         self.mark_assignment(node.target,
                 ExprNodes.binop_node(node.pos,
                                      '+',
                                      node.bound1,
                                      node.step))
     self.visitchildren(node)
     return node
開發者ID:minisin,項目名稱:cython,代碼行數:10,代碼來源:TypeInference.py

示例5: visit_ForInStatNode

 def visit_ForInStatNode(self, node):
     # TODO: Remove redundancy with range optimization...
     is_special = False
     sequence = node.iterator.sequence
     if isinstance(sequence, ExprNodes.SimpleCallNode):
         function = sequence.function
         if sequence.self is None and function.is_name:
             if function.name in ('range', 'xrange'):
                 is_special = True
                 for arg in sequence.args[:2]:
                     self.mark_assignment(node.target, arg)
                 if len(sequence.args) > 2:
                     self.mark_assignment(
                         node.target, 
                         ExprNodes.binop_node(node.pos,
                                              '+',
                                              sequence.args[0],
                                              sequence.args[2]))
     if not is_special:
         self.mark_assignment(node.target, object_expr)
     self.visitchildren(node)
     return node
開發者ID:anandu,項目名稱:pylibs,代碼行數:22,代碼來源:TypeInference.py


注:本文中的ExprNodes類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。