Commit 57a5ef18 authored by Ian Henriksen's avatar Ian Henriksen

Fixed returning types other than the expected pointer from operator&

overloads. Also fixed exception handling for operator&.
parent 599f8475
...@@ -9395,7 +9395,8 @@ class AmpersandNode(CUnopNode): ...@@ -9395,7 +9395,8 @@ class AmpersandNode(CUnopNode):
if argtype.is_pyobject: if argtype.is_pyobject:
self.error("Cannot take address of Python variable") self.error("Cannot take address of Python variable")
return self return self
self.type = PyrexTypes.c_ptr_type(argtype) if not argtype.is_cpp_class or not self.type:
self.type = PyrexTypes.c_ptr_type(argtype)
return self return self
def check_const(self): def check_const(self):
...@@ -9410,7 +9411,10 @@ class AmpersandNode(CUnopNode): ...@@ -9410,7 +9411,10 @@ class AmpersandNode(CUnopNode):
return "(&%s)" % self.operand.result() return "(&%s)" % self.operand.result()
def generate_result_code(self, code): def generate_result_code(self, code):
pass if (self.operand.type.is_cpp_class and self.exception_check == '+'):
translate_cpp_exception(code, self.pos,
"%s = %s %s;" % (self.result(), self.operator, self.operand.result()),
self.exception_value, self.in_nogil_context)
unop_node_classes = { unop_node_classes = {
......
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