Commit d304d225 authored by Dag Sverre Seljebotn's avatar Dag Sverre Seljebotn

merge

parents 3a6a907a 5fd59aa5
...@@ -3220,10 +3220,12 @@ class DictItemNode(ExprNode): ...@@ -3220,10 +3220,12 @@ class DictItemNode(ExprNode):
def generate_evaluation_code(self, code): def generate_evaluation_code(self, code):
self.key.generate_evaluation_code(code) self.key.generate_evaluation_code(code)
self.value.generate_evaluation_code(code) self.value.generate_evaluation_code(code)
def generate_disposal_code(self, code): def generate_disposal_code(self, code, free_temp=True, decref=True):
self.key.generate_disposal_code(code) self.key.generate_disposal_code(
self.value.generate_disposal_code(code) code, free_temp=free_temp, decref=decref)
self.value.generate_disposal_code(
code, free_temp=free_temp, decref=decref)
def __iter__(self): def __iter__(self):
return iter([self.key, self.value]) return iter([self.key, self.value])
...@@ -4527,7 +4529,7 @@ def binop_node(pos, operator, operand1, operand2): ...@@ -4527,7 +4529,7 @@ def binop_node(pos, operator, operand1, operand2):
# #
#------------------------------------------------------------------- #-------------------------------------------------------------------
class CoercionNode(ExprNode): class CoercionNode(NewTempExprNode):
# Abstract base class for coercion nodes. # Abstract base class for coercion nodes.
# #
# arg ExprNode node being coerced # arg ExprNode node being coerced
...@@ -4766,7 +4768,7 @@ class CloneNode(CoercionNode): ...@@ -4766,7 +4768,7 @@ class CloneNode(CoercionNode):
def generate_result_code(self, code): def generate_result_code(self, code):
pass pass
def generate_disposal_code(self, code): def generate_disposal_code(self, code, free_temp=True, decref=True):
pass pass
def allocate_temps(self, env): def allocate_temps(self, env):
...@@ -4812,9 +4814,9 @@ class PersistentNode(ExprNode): ...@@ -4812,9 +4814,9 @@ class PersistentNode(ExprNode):
self.arg.generate_disposal_code(code) self.arg.generate_disposal_code(code)
self.generate_counter += 1 self.generate_counter += 1
def generate_disposal_code(self, code): def generate_disposal_code(self, code, free_temp=True, decref=True):
if self.generate_counter == self.uses: if self.generate_counter == self.uses:
if self.type.is_pyobject: if self.type.is_pyobject and decref:
code.put_decref_clear(self.result(), self.ctype()) code.put_decref_clear(self.result(), self.ctype())
def allocate_temps(self, env, result=None): def allocate_temps(self, env, result=None):
......
...@@ -251,7 +251,7 @@ class CompilerDirectivesNode(Node): ...@@ -251,7 +251,7 @@ class CompilerDirectivesNode(Node):
self.body.annotate(code) self.body.annotate(code)
code.globalstate.directives = old code.globalstate.directives = old
class BlockNode: class BlockNode(object):
# Mixin class for nodes representing a declaration block. # Mixin class for nodes representing a declaration block.
def generate_const_definitions(self, env, code): def generate_const_definitions(self, env, code):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment