test: add erased.lean

This commit is contained in:
Leonardo de Moura 2022-09-23 05:29:42 -07:00
parent eed569153b
commit 0b4590bd69
2 changed files with 25 additions and 1 deletions

View file

@ -0,0 +1,22 @@
import Lean
/-- `erased α` is the same as `α`, except that the elements
of `erased α` are erased in the VM in the same way as types
and proofs. This can be used to track data without storing it
literally. -/
def Erased (α : Sort u) : Sort max 1 u :=
Σ's : α → Prop, ∃ a, (fun b => a = b) = s
namespace Erased
/-- Erase a value. -/
@[inline]
def mk {α} (a : α) : Erased α :=
⟨fun b => a = b, a, rfl⟩
open Lean.Compiler
set_option pp.explicit true
set_option pp.funBinderTypes true
set_option pp.letVarTypes true
set_option trace.Compiler.result true
#eval Lean.Compiler.compile #[``Erased.mk]

View file

@ -12,5 +12,7 @@ def HList.set {αs : List (Type u)} (as : HList αs) (i : Fin αs.length) (v :
| [], nil, _, _ => nil
open Lean.Compiler
set_option trace.Compiler true
set_option pp.funBinderTypes true
set_option pp.letVarTypes true
set_option trace.Compiler.result true
#eval compile #[``HList.set]