lean4-htt/tests/lean/run/kernel1.lean
Leonardo de Moura 5ffbada3df feat: add Lean.MonadEnv, Lean.MonadError, and Lean.MonadOptions
This is the first set of polymorphic methods. I will add more later,
and keep reducing code duplication.

cc @Kha
2020-08-22 16:00:43 -07:00

37 lines
766 B
Text

import Lean
open Lean
def checkDefEq (a b : Name) : CoreM Unit := do
env ← getEnv;
let a := mkConst a;
let b := mkConst b;
let r := Kernel.isDefEq env {} a b;
IO.println (toString a ++ " =?= " ++ toString b ++ " := " ++ toString r)
def a1 := 100 + 100
def a2 := 200
def a3 := 20
#eval checkDefEq `a1 `a2
#eval checkDefEq `a1 `a3
def v1 := 100000000000 + 100000000000
def v2 := 200000000000
def v3 := 200000000001
def v4 : Bool := 20000000000 > 200000000001
def v5 := 100000000000 - 100000000000
def c1 := reduceNat v1
def c2 := reduceNat v2
def c3 := reduceNat v3
def c4 := reduceBool v4
def c5 := reduceNat v5
#eval checkDefEq `c1 `c2
#eval checkDefEq `c1 `c3
#eval checkDefEq `c5 `Nat.zero
#eval checkDefEq `Nat.zero `c5
#eval checkDefEq `c4 `Bool.true