Commit 46a27f44 authored by gsamain's avatar gsamain Committed by Xavier Thompson

Make __activate__ support inheritance (C++ trick about non-virtual functions)

parent 0d6d53f8
...@@ -1021,6 +1021,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -1021,6 +1021,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
activated_class_entry = scope.lookup_here("Activated") activated_class_entry = scope.lookup_here("Activated")
if activated_class_entry: if activated_class_entry:
code.putln("struct %s;" % activated_class_entry.cname) code.putln("struct %s;" % activated_class_entry.cname)
code.putln("%s;" % activated_class_entry.type.declaration_code("__activate__(void)"))
for attr in scope.var_entries: for attr in scope.var_entries:
cname = attr.cname cname = attr.cname
if attr.type.is_cfunction and attr.type.is_static_method: if attr.type.is_cfunction and attr.type.is_static_method:
...@@ -1177,7 +1178,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -1177,7 +1178,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
def generate_cyp_class_activated_class(self, entry, code): def generate_cyp_class_activated_class(self, entry, code):
result_interface_entry = entry.scope.lookup_here("ActhonResultInterface") result_interface_entry = entry.scope.lookup_here("ActhonResultInterface")
# TODO: handle inheritance # TODO: handle inheritance
code.putln("struct %s::Activated : public CyObject {" % entry.type.empty_declaration_code()) activable_bases = ["public %s::Activated" % base.cname for base in entry.type.base_classes if base.activable]
if activable_bases:
base_classes_code = ", ".join(activable_bases)
else:
base_classes_code = "public CyObject"
code.putln("struct %s::Activated : %s {" % (entry.type.empty_declaration_code(), base_classes_code))
code.putln("%s * _passive_self;" % entry.type.empty_declaration_code()) code.putln("%s * _passive_self;" % entry.type.empty_declaration_code())
code.putln("Activated(){} // Used for inheritance, never used for classic instantiation") code.putln("Activated(){} // Used for inheritance, never used for classic instantiation")
code.putln("Activated(%s * passive_object):_passive_self(passive_object){} // Used by _passive_self.activate()" % entry.type.empty_declaration_code()) code.putln("Activated(%s * passive_object):_passive_self(passive_object){} // Used by _passive_self.activate()" % entry.type.empty_declaration_code())
......
...@@ -749,7 +749,8 @@ class Scope(object): ...@@ -749,7 +749,8 @@ class Scope(object):
act_attr_name = Naming.builtin_prefix + "_active_self" act_attr_name = Naming.builtin_prefix + "_active_self"
scope.declare_var("<active_self>", act_type, pos, cname=act_attr_name) scope.declare_var("<active_self>", act_type, pos, cname=act_attr_name)
activate_type = PyrexTypes.CFuncType(act_type, [], nogil = 1) activate_type = PyrexTypes.CFuncType(act_type, [], nogil = 1)
scope.declare_var("__activate__", activate_type, pos, cname="__activate__", defining = 1) activate_entry = scope.declare("__activate__", "__activate__", activate_type, None, 'extern')
activate_entry.is_variable = activate_entry.is_cfunction = 1
if self.is_cpp_class_scope: if self.is_cpp_class_scope:
entry.type.namespace = self.outer_scope.lookup(self.name).type entry.type.namespace = self.outer_scope.lookup(self.name).type
......
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