test: add erased.lean
This commit is contained in:
parent
eed569153b
commit
0b4590bd69
2 changed files with 25 additions and 1 deletions
22
tests/lean/run/erased.lean
Normal file
22
tests/lean/run/erased.lean
Normal 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]
|
||||
|
|
@ -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]
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue