Commit 7013323d authored by Tom Niget's avatar Tom Niget

Initial support for inheritance and mro works

parent 4dda1cb4
...@@ -178,7 +178,8 @@ struct TyStr__oo : classtype<_Base0, TyStr__oo<>> { ...@@ -178,7 +178,8 @@ struct TyStr__oo : classtype<_Base0, TyStr__oo<>> {
// getitem // getitem
struct : method { struct : method {
auto operator()(auto self, TySlice__oo<>::Obj<auto, auto, auto> slice) const { template<typename T, typename U, typename V>
auto operator()(auto self, TySlice__oo<>::Obj<T, U, V> slice) const {
auto [len, new_slice] = slice.adjust_indices(self->value.size()); auto [len, new_slice] = slice.adjust_indices(self->value.size());
Obj result; Obj result;
result.value.reserve(len); result.value.reserve(len);
......
# coding: utf-8
class class1:
def method1(self):
print("class1::method1()")
def function2():
print("function2")
return class1()
def function1():
r = function2()
print("function1()")
return r
class class2(class1):
def method2(self):
self.method1()
print("class2::method2()")
class class3(class1):
def method2(self):
self.method1()
print("class3::method2()")
class class4(class2, class3):
def method3(self):
self.method1()
print("class4::method3()")
if __name__ == "__main__":
print(">>> o1 = function1()")
o1 = function1()
print(">>> o1.method1()")
o1.method1()
print(">>> o2 = class2()")
o2 = class2()
print(">>> o2.method1()")
o2.method1()
print(">>> o2.method2()")
o2.method2()
print(">>> o3 = class3()")
o3 = class3()
print(">>> o3.method2()")
o3.method2()
print(">>> o4 = class4()")
o4 = class4()
print(">>> o4.method3()")
o4.method3()
...@@ -4,12 +4,28 @@ from typing import Iterable ...@@ -4,12 +4,28 @@ from typing import Iterable
from transpiler.phases.emit_cpp.function import emit_function from transpiler.phases.emit_cpp.function import emit_function
from transpiler.phases.emit_cpp.visitors import join, NodeVisitor from transpiler.phases.emit_cpp.visitors import join, NodeVisitor
from transpiler.phases.typing.expr import ScoperExprVisitor from transpiler.phases.typing.expr import ScoperExprVisitor
from transpiler.phases.typing.types import ConcreteType, TypeVariable, RuntimeValue from transpiler.phases.typing.types import ConcreteType, TypeVariable, RuntimeValue, TY_OBJECT, GenericInstanceType
def emit_base_type(t: list[ConcreteType]):
match t:
case []:
yield "referencemodel::object"
case [par] if isinstance(par, GenericInstanceType) and not par.generic_args:
yield "decltype(" + par.generic_parent.name() + ")"
case [head, *tail] if tail:
yield "referencemodel::meta::rebase<"
yield from emit_base_type([head])
yield ","
yield from emit_base_type(tail)
yield ">"
case _:
raise NotImplementedError("parent not handled yet: " + str(t))
def emit_class(name: str, node: ConcreteType) -> Iterable[str]: def emit_class(name: str, node: ConcreteType) -> Iterable[str]:
__TB_NODE__ = node.block_data.node __TB_NODE__ = node.block_data.node
yield f"template <typename _Base0 = referencemodel::object>" yield "template <typename _Base0 ="
yield from emit_base_type(node.get_mro()[1:-1])
yield ">"
yield f"struct {name}__oo : referencemodel::classtype<_Base0, {name}__oo<>> {{" yield f"struct {name}__oo : referencemodel::classtype<_Base0, {name}__oo<>> {{"
yield f"static constexpr std::string_view name = \"{name}\";" yield f"static constexpr std::string_view name = \"{name}\";"
......
...@@ -198,6 +198,8 @@ class ExpressionVisitor(NodeVisitor): ...@@ -198,6 +198,8 @@ class ExpressionVisitor(NodeVisitor):
yield ")" yield ")"
add_call = False
if isinstance(node.func.type, ClassTypeType): if isinstance(node.func.type, ClassTypeType):
inner = node.func.type.inner_type inner = node.func.type.inner_type
if isinstance(node.type, GenericInstanceType): if isinstance(node.type, GenericInstanceType):
...@@ -206,11 +208,15 @@ class ExpressionVisitor(NodeVisitor): ...@@ -206,11 +208,15 @@ class ExpressionVisitor(NodeVisitor):
yield "<" yield "<"
yield from join(", ", (self.visit(arg) for arg in node.type.generic_args)) yield from join(", ", (self.visit(arg) for arg in node.type.generic_args))
yield ">" yield ">"
add_call = True
yield "(" yield "("
yield from join(", ", map(self.visit, node.args)) yield from join(", ", map(self.visit, node.args))
yield ")" yield ")"
if add_call and self.generator == CoroutineMode.SYNC:
yield ".call()"
#raise NotImplementedError() #raise NotImplementedError()
# TODO # TODO
# if getattr(node, "keywords", None): # if getattr(node, "keywords", None):
......
...@@ -88,7 +88,10 @@ class NodeVisitor(UniversalVisitor): ...@@ -88,7 +88,10 @@ class NodeVisitor(UniversalVisitor):
case types.GenericInstanceType(): case types.GenericInstanceType():
yield from self.visit(node.generic_parent) yield from self.visit(node.generic_parent)
yield "<" yield "<"
if node.generic_args:
yield from join(",", map(self.visit, node.generic_args)) yield from join(",", map(self.visit, node.generic_args))
else:
yield "void"
yield ">" yield ">"
# case types.TY_LIST: # case types.TY_LIST:
# yield "typon::TyList" # yield "typon::TyList"
...@@ -104,6 +107,8 @@ class NodeVisitor(UniversalVisitor): ...@@ -104,6 +107,8 @@ class NodeVisitor(UniversalVisitor):
yield "typon::Forked" yield "typon::Forked"
case types.TY_MUTEX: case types.TY_MUTEX:
yield "typon::ArcMutex" yield "typon::ArcMutex"
# case types.UserGenericType():
# yield f"typename decltype({node.name()})::Obj"
case _: case _:
raise NotImplementedError(node) raise NotImplementedError(node)
......
...@@ -162,7 +162,7 @@ class StdlibVisitor(NodeVisitorSeq): ...@@ -162,7 +162,7 @@ class StdlibVisitor(NodeVisitorSeq):
case [prot] if is_builtin(prot, "Protocol"): case [prot] if is_builtin(prot, "Protocol"):
output.is_protocol = True output.is_protocol = True
case _: case _:
raise NotImplementedError("parents not handled yet: " + ", ".join(map(ast.unparse, node.bases))) output.parents = [p.deref() for p in bases] # TODO: what about uninstantiated generic types here?
for stmt in node.body: for stmt in node.body:
visitor.visit(stmt) visitor.visit(stmt)
for deco_node in node.decorator_list: for deco_node in node.decorator_list:
......
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