Commit 6cf33847 authored by Stefan Behnel's avatar Stefan Behnel

fix the wrapper setup for inherited special methods by inheriting them only in...

fix the wrapper setup for inherited special methods by inheriting them only in PyPy (as a work-around for its broken PyType_Ready())
parent d0d7e370
...@@ -188,10 +188,29 @@ class SlotDescriptor(object): ...@@ -188,10 +188,29 @@ class SlotDescriptor(object):
return guard return guard
def generate(self, scope, code): def generate(self, scope, code):
end_pypy_guard = False
if self.is_initialised_dynamically: if self.is_initialised_dynamically:
value = 0 value = "0"
else: else:
value = self.slot_code(scope) value = self.slot_code(scope)
if value == "0" and self.is_inherited:
# PyPy currently has a broken PyType_Ready() that fails to
# inherit some slots. To work around this, we explicitly
# set inherited slots here, but only in PyPy since CPython
# handles this better than we do.
inherited_value = value
current_scope = scope
while (inherited_value == "0"
and current_scope.parent_type
and current_scope.parent_type.base_type
and current_scope.parent_type.base_type.scope):
current_scope = current_scope.parent_type.base_type.scope
inherited_value = self.slot_code(current_scope)
if inherited_value != "0":
code.putln("#if CYTHON_COMPILING_IN_PYPY")
code.putln("%s, /*%s*/" % (inherited_value, self.slot_name))
code.putln("#else")
end_pypy_guard = True
preprocessor_guard = self.preprocessor_guard_code() preprocessor_guard = self.preprocessor_guard_code()
if preprocessor_guard: if preprocessor_guard:
code.putln(preprocessor_guard) code.putln(preprocessor_guard)
...@@ -201,6 +220,8 @@ class SlotDescriptor(object): ...@@ -201,6 +220,8 @@ class SlotDescriptor(object):
code.putln("0, /*reserved*/") code.putln("0, /*reserved*/")
if preprocessor_guard: if preprocessor_guard:
code.putln("#endif") code.putln("#endif")
if end_pypy_guard:
code.putln("#endif")
# Some C implementations have trouble statically # Some C implementations have trouble statically
# initialising a global with a pointer to an extern # initialising a global with a pointer to an extern
...@@ -272,9 +293,6 @@ class MethodSlot(SlotDescriptor): ...@@ -272,9 +293,6 @@ class MethodSlot(SlotDescriptor):
entry = scope.lookup_here(method_name) entry = scope.lookup_here(method_name)
if entry and entry.func_cname: if entry and entry.func_cname:
return entry.func_cname return entry.func_cname
if (self.is_inherited and scope.parent_type and scope.parent_type.base_type
and scope.parent_type.base_type.scope):
return self.slot_code(scope.parent_type.base_type.scope)
return "0" return "0"
......
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