Kind/book/Kind.verify.kind2
2024-02-20 19:23:15 -03:00

11 lines
337 B
Plaintext

Kind.verify
: ∀(term: Kind.Term)
∀(type: Kind.Term)
∀(dep: Nat)
(Maybe Kind.Term)
= λterm λtype λdep
let bind = (Maybe.bind Kind.Term Kind.Term)
let pure = (Maybe.some Kind.Term)
let none = (Maybe.none Kind.Term)
(bind (Kind.infer term dep) λinfer
(Kind.report (Kind.equal infer type dep) infer type term dep))