2014-05-21 16:29:25 -07:00
|
|
|
function display_type(env, t)
|
|
|
|
print(tostring(t) .. " : " .. tostring(env:normalize(env:type_check(t))))
|
|
|
|
end
|
|
|
|
|
2014-07-22 09:43:18 -07:00
|
|
|
local A = Local("A", Prop)
|
2014-05-21 16:29:25 -07:00
|
|
|
local env = environment()
|
|
|
|
local retraction = Const("retraction")
|
|
|
|
|
|
|
|
env = add_inductive(env,
|
2014-07-22 09:43:18 -07:00
|
|
|
"retraction", Prop,
|
2014-05-21 16:29:25 -07:00
|
|
|
"inj", Pi(A, retraction))
|
|
|
|
|
|
|
|
local u = global_univ("u")
|
2014-06-13 08:26:05 -07:00
|
|
|
env = env:add_universe("u")
|
2014-07-22 09:43:18 -07:00
|
|
|
local a = Local("a", Prop)
|
2014-05-21 16:29:25 -07:00
|
|
|
local r = Local("r", retraction)
|
|
|
|
|
2014-09-04 15:03:59 -07:00
|
|
|
local rec = Const({"retraction", "rec"})
|
2014-05-21 16:29:25 -07:00
|
|
|
display_type(env, rec)
|
2014-07-22 09:43:18 -07:00
|
|
|
local proj = Fun(r, rec(Prop, Fun(a, a), r))
|
2014-05-21 16:29:25 -07:00
|
|
|
local inj = Const("inj")
|
|
|
|
|
|
|
|
assert(not pcall(function() display_type(env, Fun(a, proj(inj(a)))) end))
|