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
|
(*
** for testing [libats/stkarray]
*)
(* ****** ****** *)
//
// Author: Hongwei Xi
// Authoremail: hwxi AT cs DOT bu DOT edu
// Start time: September, 2013
//
(* ****** ****** *)
//
#include
"share/atspre_staload.hats"
//
(* ****** ****** *)
staload "libats/SATS/stkarray.sats"
staload _(*anon*) = "libats/DATS/stkarray.dats"
(* ****** ****** *)
val () =
{
//
val M = i2sz(2)
//
val stk =
stkarray_make_cap<int> (M)
//
val () = assertloc (stkarray_get_size (stk) = 0)
val () = assertloc (stkarray_get_capacity (stk) = M)
//
val () = stkarray_insert (stk, 0)
val-(0) = stkarray_takeout (stk)
val-~None_vt() = stkarray_takeout_opt (stk)
//
val () = assertloc (stkarray_get_size (stk) = 0)
//
val-~None_vt() = stkarray_insert_opt (stk, 1)
val-~None_vt() = stkarray_insert_opt (stk, 2)
//
val () = fprintln! (stdout_ref, "stk = ", stk)
//
val-~Some_vt(3) = stkarray_insert_opt (stk, 3)
val () = assertloc (stkarray_get_size (stk) = 2)
val-(2) = stkarray_takeout (stk)
val-(1) = stkarray_takeout (stk)
val-~None_vt() = stkarray_takeout_opt (stk)
val () = assertloc (stkarray_get_size (stk) = 0)
//
val () = stkarray_free_nil (stk)
//
} (* end of [val] *)
(* ****** ****** *)
implement main0 () = ()
(* ****** ****** *)
(* end of [libats_stkarray.dats] *)
|