Solution [blog/lti/subtype_code]
Solution [blog/lti/subtype_code]
/// l <: r
struct Subtype {
l : Type
r : Type
}
pub fn subtype(self : Subtype) -> Bool {
match (self.l, self.r) {
(TyVar(v1), TyVar(v2)) => v1 == v2
(_, TyTop) => true
(TyBot, _) => true
(TyFun(xs1, r, s), TyFun(xs2, t, u)) if xs1 == xs2 =>
subtypes(t, r) && { l: s, r: u }.subtype()
_ => false
}
}