blob: dacb32f1412a31608610615f3dda6797701ef7bb [file] [log] [blame]
"""Same type check for RTypes."""
from mypyc.ops import (
RType, RTypeVisitor, RInstance, RPrimitive, RTuple, RVoid,
FuncSignature, RUnion
)
def is_same_type(a: RType, b: RType) -> bool:
return a.accept(SameTypeVisitor(b))
def is_same_signature(a: FuncSignature, b: FuncSignature) -> bool:
return (len(a.args) == len(b.args)
and is_same_type(a.ret_type, b.ret_type)
and all(is_same_type(t1.type, t2.type) and t1.name == t2.name
for t1, t2 in zip(a.args, b.args)))
def is_same_method_signature(a: FuncSignature, b: FuncSignature) -> bool:
return (len(a.args) == len(b.args)
and is_same_type(a.ret_type, b.ret_type)
and all(is_same_type(t1.type, t2.type) and t1.name == t2.name
for t1, t2 in zip(a.args[1:], b.args[1:])))
class SameTypeVisitor(RTypeVisitor[bool]):
def __init__(self, right: RType) -> None:
self.right = right
def visit_rinstance(self, left: RInstance) -> bool:
return isinstance(self.right, RInstance) and left.name == self.right.name
def visit_runion(self, left: RUnion) -> bool:
if isinstance(self.right, RUnion):
items = list(self.right.items)
for left_item in left.items:
for j, right_item in enumerate(items):
if is_same_type(left_item, right_item):
del items[j]
break
else:
return False
return not items
return False
def visit_rprimitive(self, left: RPrimitive) -> bool:
return left is self.right
def visit_rtuple(self, left: RTuple) -> bool:
return (isinstance(self.right, RTuple)
and len(self.right.types) == len(left.types)
and all(is_same_type(t1, t2) for t1, t2 in zip(left.types, self.right.types)))
def visit_rvoid(self, left: RVoid) -> bool:
return isinstance(self.right, RVoid)