Commit 706e1bc8 authored by Xavier Thompson's avatar Xavier Thompson

Synthesize wrapper classes for forward-declared cypclasses also

parent df64e21d
...@@ -151,10 +151,6 @@ class CypclassWrapperInjection(CythonTransform): ...@@ -151,10 +151,6 @@ class CypclassWrapperInjection(CythonTransform):
# whether the is declared with ':' and a suite, or just a forward declaration # whether the is declared with ':' and a suite, or just a forward declaration
node_has_suite = node.attributes is not None node_has_suite = node.attributes is not None
# TODO: forward declare wrapper classes too ?
if not node_has_suite:
return None
# TODO: take nesting into account for the name # TODO: take nesting into account for the name
# TODO: check that there is no collision with another name # TODO: check that there is no collision with another name
cclass_name = EncodedString("%s_cyp_wrapper" % node.name) cclass_name = EncodedString("%s_cyp_wrapper" % node.name)
...@@ -181,13 +177,17 @@ class CypclassWrapperInjection(CythonTransform): ...@@ -181,13 +177,17 @@ class CypclassWrapperInjection(CythonTransform):
cclass_bases = TupleNode(node.pos, args=bases_args) cclass_bases = TupleNode(node.pos, args=bases_args)
stats = [] if node_has_suite:
if not bases_args: stats = []
underlying_cyobject = self.synthesize_underlying_cyobject_attribute(node) if not bases_args:
stats.append(underlying_cyobject) underlying_cyobject = self.synthesize_underlying_cyobject_attribute(node)
cclass_body = Nodes.StatListNode(pos=node.pos, stats=stats) stats.append(underlying_cyobject)
cclass_body = Nodes.StatListNode(pos=node.pos, stats=stats)
cclass_doc = EncodedString("Python Object wrapper for underlying cypclass %s" % node.name)
cclass_doc = EncodedString("Python Object wrapper for underlying cypclass %s" % node.name) else:
cclass_body = cclass_doc = None
wrapper = Nodes.CypclassWrapperDefNode( wrapper = Nodes.CypclassWrapperDefNode(
node.pos, node.pos,
......
...@@ -5373,6 +5373,8 @@ class CypclassWrapperDefNode(CClassDefNode): ...@@ -5373,6 +5373,8 @@ class CypclassWrapperDefNode(CClassDefNode):
self.insert_cypclass_method_wrappers(env) self.insert_cypclass_method_wrappers(env)
def insert_cypclass_method_wrappers(self, env): def insert_cypclass_method_wrappers(self, env):
if self.wrapped_cypclass.attributes is None:
return
for attr in self.wrapped_cypclass.attributes: for attr in self.wrapped_cypclass.attributes:
if isinstance(attr, CFuncDefNode): if isinstance(attr, CFuncDefNode):
py_method_wrapper = self.synthesize_cypclass_method_wrapper(attr, env) py_method_wrapper = self.synthesize_cypclass_method_wrapper(attr, env)
......
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