Backed out changeset 56c6f2f22f4a
authorDag Sverre Seljebotn <dagss@student.matnat.uio.no>
Thu, 27 Nov 2008 11:03:12 +0000 (12:03 +0100)
committerDag Sverre Seljebotn <dagss@student.matnat.uio.no>
Thu, 27 Nov 2008 11:03:12 +0000 (12:03 +0100)
Cython/Compiler/ExprNodes.py

index b6cba5f911e733ebda8486f7deb8bf1064dfbcbe..78fd7779375e904d2720d4262e184e861f47d775 100644 (file)
@@ -1224,24 +1224,17 @@ class NameNode(AtomicExprNode):
             rhs.generate_post_assignment_code(code)
 
     def generate_acquire_buffer(self, rhs, code):
+        rhstmp = code.funcstate.allocate_temp(self.entry.type)
         buffer_aux = self.entry.buffer_aux
         bufstruct = buffer_aux.buffer_info_var.cname
-
-        value_is_temp = rhs.is_temp
-        if value_is_temp:
-            rhstmp = rhs.result_as(self.ctype())
-        else:
-            rhstmp = code.funcstate.allocate_temp(self.entry.type)
-            code.putln('%s = %s;' % (rhstmp, rhs.result_as(self.ctype())))
-            code.put_incref(rhstmp, self.entry.type)
+        code.putln('%s = %s;' % (rhstmp, rhs.result_as(self.ctype())))
 
         import Buffer
         Buffer.put_assign_to_buffer(self.result(), rhstmp, buffer_aux, self.entry.type,
                                     is_initialized=not self.lhs_of_first_assignment,
                                     pos=self.pos, code=code)
-        if not value_is_temp:
-            code.put_decref_clear(rhstmp, self.entry.type)
-            code.funcstate.release_temp(rhstmp)
+        code.putln("%s = 0;" % rhstmp)
+        code.funcstate.release_temp(rhstmp)
     
     def generate_deletion_code(self, code):
         if self.entry is None: