summaryrefslogtreecommitdiff
path: root/tests/fstar/misc/External.Funs.fst
blob: e26014ac593d25c5f7d396af371ca49b75be5a1c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
(** THIS FILE WAS AUTOMATICALLY GENERATED BY AENEAS *)
(** [external]: function definitions *)
module External.Funs
open Primitives
include External.Types
include External.Opaque

#set-options "--z3rlimit 50 --fuel 1 --ifuel 1"

(** [external::swap]: forward function *)
let swap (t : Type0) (x : t) (y : t) (st : state) : result (state & unit) =
  let* (st0, _) = core_mem_swap t x y st in
  let* (st1, _) = core_mem_swap_back0 t x y st st0 in
  let* (st2, _) = core_mem_swap_back1 t x y st st1 in
  Return (st2, ())

(** [external::swap]: backward function 0 *)
let swap_back
  (t : Type0) (x : t) (y : t) (st : state) (st0 : state) :
  result (state & (t & t))
  =
  let* (st1, _) = core_mem_swap t x y st in
  let* (st2, x0) = core_mem_swap_back0 t x y st st1 in
  let* (_, y0) = core_mem_swap_back1 t x y st st2 in
  Return (st0, (x0, y0))

(** [external::test_new_non_zero_u32]: forward function *)
let test_new_non_zero_u32
  (x : u32) (st : state) : result (state & core_num_nonzero_NonZeroU32_t) =
  let* (st0, o) = core_num_nonzero_NonZeroU32_new x st in
  core_option_Option_unwrap core_num_nonzero_NonZeroU32_t o st0

(** [external::test_vec]: forward function *)
let test_vec : result unit =
  let v = alloc_vec_Vec_new u32 in
  let* _ = alloc_vec_Vec_push u32 v 0 in
  Return ()

(** Unit test for [external::test_vec] *)
let _ = assert_norm (test_vec = Return ())

(** [external::custom_swap]: forward function *)
let custom_swap (t : Type0) (x : t) (y : t) (st : state) : result (state & t) =
  let* (st0, _) = core_mem_swap t x y st in
  let* (st1, x0) = core_mem_swap_back0 t x y st st0 in
  let* (st2, _) = core_mem_swap_back1 t x y st st1 in
  Return (st2, x0)

(** [external::custom_swap]: backward function 0 *)
let custom_swap_back
  (t : Type0) (x : t) (y : t) (st : state) (ret : t) (st0 : state) :
  result (state & (t & t))
  =
  let* (st1, _) = core_mem_swap t x y st in
  let* (st2, _) = core_mem_swap_back0 t x y st st1 in
  let* (_, y0) = core_mem_swap_back1 t x y st st2 in
  Return (st0, (ret, y0))

(** [external::test_custom_swap]: forward function *)
let test_custom_swap (x : u32) (y : u32) (st : state) : result (state & unit) =
  let* (st0, _) = custom_swap u32 x y st in Return (st0, ())

(** [external::test_custom_swap]: backward function 0 *)
let test_custom_swap_back
  (x : u32) (y : u32) (st : state) (st0 : state) :
  result (state & (u32 & u32))
  =
  custom_swap_back u32 x y st 1 st0

(** [external::test_swap_non_zero]: forward function *)
let test_swap_non_zero (x : u32) (st : state) : result (state & u32) =
  let* (st0, _) = swap u32 x 0 st in
  let* (st1, (x0, _)) = swap_back u32 x 0 st st0 in
  if x0 = 0 then Fail Failure else Return (st1, x0)