21 lines
612 B
Lua
21 lines
612 B
Lua
|
local env = empty_environment()
|
||
|
local g = name_generator("tst")
|
||
|
local tc = type_checker(env, g)
|
||
|
assert(is_type_checker(tc))
|
||
|
local a = Const("a")
|
||
|
local t = Fun(a, Bool, a)
|
||
|
local b = Const("b")
|
||
|
print(t(b))
|
||
|
assert(tc:whnf(t(b)) == b)
|
||
|
local cs = {}
|
||
|
local tc2 = type_checker(env, g, constraint_handler(function (c) print(c); cs[#cs+1] = c end))
|
||
|
assert(tc:check(Bool) == mk_sort(mk_level_one()))
|
||
|
print(tc:infer(t))
|
||
|
local m = mk_metavar("m1", mk_metavar("m2", mk_sort(mk_meta_univ("u"))))
|
||
|
print(tc:infer(m))
|
||
|
local t2 = Fun(a, Bool, m(a))
|
||
|
print(t2)
|
||
|
print(tc2:check(t))
|
||
|
print(tc2:check(t2))
|
||
|
assert(#cs == 2)
|