diff options
Diffstat (limited to '')
| -rw-r--r-- | tests/lean/Hashmap/Funs.lean | 5 | ||||
| -rw-r--r-- | tests/lean/Hashmap/Properties.lean | 4 | ||||
| -rw-r--r-- | tests/lean/Hashmap/Types.lean | 1 | ||||
| -rw-r--r-- | tests/lean/HashmapMain/Funs.lean | 5 | ||||
| -rw-r--r-- | tests/lean/HashmapMain/Types.lean | 1 | 
5 files changed, 12 insertions, 4 deletions
| diff --git a/tests/lean/Hashmap/Funs.lean b/tests/lean/Hashmap/Funs.lean index 870693b5..d6796932 100644 --- a/tests/lean/Hashmap/Funs.lean +++ b/tests/lean/Hashmap/Funs.lean @@ -3,6 +3,7 @@  import Base  import Hashmap.Types  open Primitives +  namespace hashmap  /- [hashmap::hash_key]: forward function -/ @@ -238,7 +239,7 @@ def HashMap.contains_key      let hash ← hash_key key      let i := Vec.len (List T) self.slots      let hash_mod ← hash % i -    let l ← Vec.index (List T) self.slots hash_mod +    let l ← Vec.index_shared (List T) self.slots hash_mod      HashMap.contains_key_in_list T key l  /- [hashmap::HashMap::{0}::get_in_list]: loop 0: forward function -/ @@ -261,7 +262,7 @@ def HashMap.get (T : Type) (self : HashMap T) (key : Usize) : Result T :=      let hash ← hash_key key      let i := Vec.len (List T) self.slots      let hash_mod ← hash % i -    let l ← Vec.index (List T) self.slots hash_mod +    let l ← Vec.index_shared (List T) self.slots hash_mod      HashMap.get_in_list T key l  /- [hashmap::HashMap::{0}::get_mut_in_list]: loop 0: forward function -/ diff --git a/tests/lean/Hashmap/Properties.lean b/tests/lean/Hashmap/Properties.lean index 3652f608..ab95b854 100644 --- a/tests/lean/Hashmap/Properties.lean +++ b/tests/lean/Hashmap/Properties.lean @@ -284,6 +284,10 @@ def mk_opaque {α : Sort u} (x : α) : { y : α // y = x}  :=  attribute [pp_dot] List.length -- use the dot notation when printing  set_option pp.coercions false -- do not print coercions with ↑ (this doesn't parse) +-- The proof below is a bit expensive, so we need to increase the maximum number +-- of heart beats +set_option maxHeartbeats 400000 +  theorem insert_no_resize_spec {α : Type} (hm : HashMap α) (key : Usize) (value : α)    (hinv : hm.inv) (hnsat : hm.lookup key = none → hm.len_s < Usize.max) :    ∃ nhm, hm.insert_no_resize α key value = ret nhm  ∧ diff --git a/tests/lean/Hashmap/Types.lean b/tests/lean/Hashmap/Types.lean index 6606cf9e..6455798d 100644 --- a/tests/lean/Hashmap/Types.lean +++ b/tests/lean/Hashmap/Types.lean @@ -2,6 +2,7 @@  -- [hashmap]: type definitions  import Base  open Primitives +  namespace hashmap  /- [hashmap::List] -/ diff --git a/tests/lean/HashmapMain/Funs.lean b/tests/lean/HashmapMain/Funs.lean index 610bae46..74fe8a54 100644 --- a/tests/lean/HashmapMain/Funs.lean +++ b/tests/lean/HashmapMain/Funs.lean @@ -4,6 +4,7 @@ import Base  import HashmapMain.Types  import HashmapMain.FunsExternal  open Primitives +  namespace hashmap_main  /- [hashmap_main::hashmap::hash_key]: forward function -/ @@ -260,7 +261,7 @@ def hashmap.HashMap.contains_key      let hash ← hashmap.hash_key key      let i := Vec.len (hashmap.List T) self.slots      let hash_mod ← hash % i -    let l ← Vec.index (hashmap.List T) self.slots hash_mod +    let l ← Vec.index_shared (hashmap.List T) self.slots hash_mod      hashmap.HashMap.contains_key_in_list T key l  /- [hashmap_main::hashmap::HashMap::{0}::get_in_list]: loop 0: forward function -/ @@ -285,7 +286,7 @@ def hashmap.HashMap.get      let hash ← hashmap.hash_key key      let i := Vec.len (hashmap.List T) self.slots      let hash_mod ← hash % i -    let l ← Vec.index (hashmap.List T) self.slots hash_mod +    let l ← Vec.index_shared (hashmap.List T) self.slots hash_mod      hashmap.HashMap.get_in_list T key l  /- [hashmap_main::hashmap::HashMap::{0}::get_mut_in_list]: loop 0: forward function -/ diff --git a/tests/lean/HashmapMain/Types.lean b/tests/lean/HashmapMain/Types.lean index 3b3d0d7c..2b5cbd6c 100644 --- a/tests/lean/HashmapMain/Types.lean +++ b/tests/lean/HashmapMain/Types.lean @@ -2,6 +2,7 @@  -- [hashmap_main]: type definitions  import Base  open Primitives +  namespace hashmap_main  /- [hashmap_main::hashmap::List] -/ | 
