2015-02-03 15:15:04 -08:00
|
|
|
import data.nat.basic
|
2014-09-03 16:00:38 -07:00
|
|
|
open nat
|
2014-08-05 08:37:03 -07:00
|
|
|
|
|
|
|
definition two1 : nat := 2
|
|
|
|
definition two2 : nat := succ (succ (zero))
|
2014-10-02 16:20:52 -07:00
|
|
|
constant f : nat → nat → nat
|
2014-08-05 08:37:03 -07:00
|
|
|
|
|
|
|
(*
|
|
|
|
local tc = type_checker_with_hints(get_env(), true)
|
|
|
|
local plugin = whnf_match_plugin(tc)
|
|
|
|
function tst_match(p, t)
|
|
|
|
local r1, r2 = match(p, t, plugin)
|
|
|
|
assert(r1)
|
|
|
|
print("--------------")
|
|
|
|
for i = 1, #r1 do
|
|
|
|
print(" expr:#" .. i .. " := " .. tostring(r1[i]))
|
|
|
|
end
|
|
|
|
for i = 1, #r2 do
|
|
|
|
print(" lvl:#" .. i .. " := " .. tostring(r2[i]))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-02-03 15:15:04 -08:00
|
|
|
local nat = Const("nat")
|
2014-08-05 08:37:03 -07:00
|
|
|
local f = Const("f")
|
|
|
|
local two1 = Const("two1")
|
|
|
|
local two2 = Const("two2")
|
2014-09-04 16:36:06 -07:00
|
|
|
local succ = Const({"nat", "succ"})
|
2015-02-03 15:15:04 -08:00
|
|
|
local V0 = mk_idx_meta(0, nat)
|
|
|
|
tst_match(f(succ(V0), two1), f(two2, two2))
|
2014-08-05 08:37:03 -07:00
|
|
|
*)
|