lean4-htt/library/init/lean/ir/instances.lean
Leonardo de Moura 71dd8653bc feat(library/init/core): decidable_eq is a proper class
We need this to take advantage of the new indexing structure we are
going to add to improve performance.
2018-09-07 16:38:11 -07:00

64 lines
2.5 KiB
Text

/-
Copyright (c) 2018 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: Leonardo de Moura
-/
prelude
import init.lean.ir.ir
namespace lean
namespace ir
/- TEMPORARY HACK for defining (decidable_eq type) until we bootstrap new compiler -/
def type2id : type → nat
| type.bool := 0 | type.byte := 1
| type.uint16 := 2 | type.uint32 := 3 | type.uint64 := 4 | type.usize := 5
| type.int16 := 6 | type.int32 := 7 | type.int64 := 8
| type.float := 9 | type.double := 10 | type.object := 11
def id2type : nat → type
| 0 := type.bool | 1 := type.byte
| 2 := type.uint16 | 3 := type.uint32 | 4 := type.uint64 | 5 := type.usize
| 6 := type.int16 | 7 := type.int32 | 8 := type.int64
| 9 := type.float | 10 := type.double | _ := type.object
theorem id2type_type2id_eq : ∀ (ty : type), id2type (type2id ty) = ty
| type.bool := rfl | type.byte := rfl
| type.uint16 := rfl | type.uint32 := rfl | type.uint64 := rfl | type.usize := rfl
| type.int16 := rfl | type.int32 := rfl | type.int64 := rfl
| type.float := rfl | type.double := rfl | type.object := rfl
instance type_has_dec_eq : decidable_eq type :=
{dec_eq := λ t₁ t₂,
if h : type2id t₁ = type2id t₂
then is_true (id2type_type2id_eq t₁ ▸ id2type_type2id_eq t₂ ▸ h ▸ rfl)
else is_false (λ h', absurd rfl (@eq.subst _ (λ t, ¬ type2id t = type2id t₂) _ _ h' h))}
/- END of TEMPORARY HACK for (decidable_eq type) -/
instance : has_coe string fnid :=
⟨mk_simple_name⟩
-- TODO: move collection declarations to another file
instance var_has_lt : has_lt var := (name.has_lt_quick : has_lt name)
instance blockid_has_lt : has_lt blockid := (name.has_lt_quick : has_lt name)
instance fnid_has_lt : has_lt fnid := (name.has_lt_quick : has_lt name)
attribute [derive decidable_eq hashable] var blockid fnid
def var_set := rbtree var (<)
def blockid_set := rbtree blockid (<)
def context := rbmap var type (<)
def var2blockid := rbmap var blockid (<)
def fnid2string := rbmap fnid string (<)
def fnid_set := rbtree fnid (<)
def mk_var_set : var_set := mk_rbtree var (<)
def mk_blockid_set : blockid_set := mk_rbtree blockid (<)
def mk_var2blockid : var2blockid := mk_rbmap var blockid (<)
def mk_context : context := mk_rbmap var type (<)
def mk_fnid2string : fnid2string := mk_rbmap fnid string (<)
def mk_fnid_set : fnid_set := mk_rbtree fnid (<)
instance : inhabited result :=
⟨⟨type.bool⟩⟩
end ir
end lean