summaryrefslogtreecommitdiff
path: root/tests/lean/HashmapMain
diff options
context:
space:
mode:
Diffstat (limited to 'tests/lean/HashmapMain')
-rw-r--r--tests/lean/HashmapMain/ExternalFuns.lean9
-rw-r--r--tests/lean/HashmapMain/Funs.lean31
-rw-r--r--tests/lean/HashmapMain/Opaque.lean7
-rw-r--r--tests/lean/HashmapMain/Types.lean5
4 files changed, 35 insertions, 17 deletions
diff --git a/tests/lean/HashmapMain/ExternalFuns.lean b/tests/lean/HashmapMain/ExternalFuns.lean
new file mode 100644
index 00000000..bc831158
--- /dev/null
+++ b/tests/lean/HashmapMain/ExternalFuns.lean
@@ -0,0 +1,9 @@
+import Base
+import HashmapMain.Types
+import HashmapMain.Opaque
+
+namespace HashmapMain
+
+def opaque_defs : OpaqueDefs := by sorry
+
+end HashmapMain
diff --git a/tests/lean/HashmapMain/Funs.lean b/tests/lean/HashmapMain/Funs.lean
index a59a9f26..34a0eca1 100644
--- a/tests/lean/HashmapMain/Funs.lean
+++ b/tests/lean/HashmapMain/Funs.lean
@@ -5,6 +5,8 @@ import HashmapMain.Types
import HashmapMain.ExternalFuns
open Primitives
+namespace HashmapMain
+
/- [hashmap_main::hashmap::hash_key] -/
def hashmap_hash_key_fwd (k : Usize) : Result Usize :=
Result.ret k
@@ -92,7 +94,7 @@ def hashmap_hash_map_len_fwd
/- [hashmap_main::hashmap::HashMap::{0}::insert_in_list] -/
divergent def hashmap_hash_map_insert_in_list_loop_fwd
(T : Type) (key : Usize) (value : T) (ls : hashmap_list_t T) : Result Bool :=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey cvalue tl =>
if ckey = key
then Result.ret false
@@ -109,7 +111,7 @@ divergent def hashmap_hash_map_insert_in_list_loop_back
(T : Type) (key : Usize) (value : T) (ls : hashmap_list_t T) :
Result (hashmap_list_t T)
:=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey cvalue tl =>
if ckey = key
then Result.ret (hashmap_list_t.Cons ckey value tl)
@@ -173,7 +175,7 @@ divergent def hashmap_hash_map_move_elements_from_list_loop_fwd_back
(T : Type) (ntable : hashmap_hash_map_t T) (ls : hashmap_list_t T) :
Result (hashmap_hash_map_t T)
:=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons k v tl =>
do
let ntable0 ← hashmap_hash_map_insert_no_resize_fwd_back T ntable k v
@@ -256,7 +258,7 @@ def hashmap_hash_map_insert_fwd_back
/- [hashmap_main::hashmap::HashMap::{0}::contains_key_in_list] -/
divergent def hashmap_hash_map_contains_key_in_list_loop_fwd
(T : Type) (key : Usize) (ls : hashmap_list_t T) : Result Bool :=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey t tl =>
if ckey = key
then Result.ret true
@@ -282,7 +284,7 @@ def hashmap_hash_map_contains_key_fwd
/- [hashmap_main::hashmap::HashMap::{0}::get_in_list] -/
divergent def hashmap_hash_map_get_in_list_loop_fwd
(T : Type) (key : Usize) (ls : hashmap_list_t T) : Result T :=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey cvalue tl =>
if ckey = key
then Result.ret cvalue
@@ -308,7 +310,7 @@ def hashmap_hash_map_get_fwd
/- [hashmap_main::hashmap::HashMap::{0}::get_mut_in_list] -/
divergent def hashmap_hash_map_get_mut_in_list_loop_fwd
(T : Type) (ls : hashmap_list_t T) (key : Usize) : Result T :=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey cvalue tl =>
if ckey = key
then Result.ret cvalue
@@ -325,7 +327,7 @@ divergent def hashmap_hash_map_get_mut_in_list_loop_back
(T : Type) (ls : hashmap_list_t T) (key : Usize) (ret0 : T) :
Result (hashmap_list_t T)
:=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey cvalue tl =>
if ckey = key
then Result.ret (hashmap_list_t.Cons ckey ret0 tl)
@@ -373,14 +375,14 @@ def hashmap_hash_map_get_mut_back
/- [hashmap_main::hashmap::HashMap::{0}::remove_from_list] -/
divergent def hashmap_hash_map_remove_from_list_loop_fwd
(T : Type) (key : Usize) (ls : hashmap_list_t T) : Result (Option T) :=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey t tl =>
if ckey = key
then
let mv_ls :=
mem_replace_fwd (hashmap_list_t T) (hashmap_list_t.Cons ckey t tl)
hashmap_list_t.Nil
- match h: mv_ls with
+ match mv_ls with
| hashmap_list_t.Cons i cvalue tl0 => Result.ret (Option.some cvalue)
| hashmap_list_t.Nil => Result.fail Error.panic
else hashmap_hash_map_remove_from_list_loop_fwd T key tl
@@ -396,14 +398,14 @@ divergent def hashmap_hash_map_remove_from_list_loop_back
(T : Type) (key : Usize) (ls : hashmap_list_t T) :
Result (hashmap_list_t T)
:=
- match h: ls with
+ match ls with
| hashmap_list_t.Cons ckey t tl =>
if ckey = key
then
let mv_ls :=
mem_replace_fwd (hashmap_list_t T) (hashmap_list_t.Cons ckey t tl)
hashmap_list_t.Nil
- match h: mv_ls with
+ match mv_ls with
| hashmap_list_t.Cons i cvalue tl0 => Result.ret tl0
| hashmap_list_t.Nil => Result.fail Error.panic
else
@@ -429,7 +431,7 @@ def hashmap_hash_map_remove_fwd
let l ←
vec_index_mut_fwd (hashmap_list_t T) self.hashmap_hash_map_slots hash_mod
let x ← hashmap_hash_map_remove_from_list_fwd T key l
- match h: x with
+ match x with
| Option.none => Result.ret Option.none
| Option.some x0 =>
do
@@ -449,7 +451,7 @@ def hashmap_hash_map_remove_back
let l ←
vec_index_mut_fwd (hashmap_list_t T) self.hashmap_hash_map_slots hash_mod
let x ← hashmap_hash_map_remove_from_list_fwd T key l
- match h: x with
+ match x with
| Option.none =>
do
let l0 ← hashmap_hash_map_remove_from_list_back T key l
@@ -505,7 +507,7 @@ def hashmap_test1_fwd : Result Unit :=
let x ←
hashmap_hash_map_remove_fwd U64 hm4
(Usize.ofInt 1024 (by intlit))
- match h: x with
+ match x with
| Option.none => Result.fail Error.panic
| Option.some x0 =>
if not (x0 = (U64.ofInt 56 (by intlit)))
@@ -555,3 +557,4 @@ def main_fwd : Result Unit :=
/- Unit test for [hashmap_main::main] -/
#assert (main_fwd == .ret ())
+end HashmapMain
diff --git a/tests/lean/HashmapMain/Opaque.lean b/tests/lean/HashmapMain/Opaque.lean
index bef4f3fb..10e4d8bd 100644
--- a/tests/lean/HashmapMain/Opaque.lean
+++ b/tests/lean/HashmapMain/Opaque.lean
@@ -4,13 +4,16 @@ import Base
import HashmapMain.Types
open Primitives
+namespace HashmapMain
+
structure OpaqueDefs where
/- [hashmap_main::hashmap_utils::deserialize] -/
hashmap_utils_deserialize_fwd
- : State -> Result (State × (hashmap_hash_map_t U64))
+ : State → Result (State × (hashmap_hash_map_t U64))
/- [hashmap_main::hashmap_utils::serialize] -/
hashmap_utils_serialize_fwd
- : hashmap_hash_map_t U64 -> State -> Result (State × Unit)
+ : hashmap_hash_map_t U64 → State → Result (State × Unit)
+end HashmapMain
diff --git a/tests/lean/HashmapMain/Types.lean b/tests/lean/HashmapMain/Types.lean
index 858e1c51..b91ff3a7 100644
--- a/tests/lean/HashmapMain/Types.lean
+++ b/tests/lean/HashmapMain/Types.lean
@@ -3,9 +3,11 @@
import Base
open Primitives
+namespace HashmapMain
+
/- [hashmap_main::hashmap::List] -/
inductive hashmap_list_t (T : Type) :=
-| Cons : Usize -> T -> hashmap_list_t T -> hashmap_list_t T
+| Cons : Usize → T → hashmap_list_t T → hashmap_list_t T
| Nil : hashmap_list_t T
/- [hashmap_main::hashmap::HashMap] -/
@@ -18,3 +20,4 @@ structure hashmap_hash_map_t (T : Type) where
/- The state type used in the state-error monad -/
axiom State : Type
+end HashmapMain