File: libats_deqarray.dats

package info (click to toggle)
ats2-lang 0.4.2-4
  • links: PTS
  • area: main
  • in suites:
  • size: 40,524 kB
  • sloc: ansic: 389,898; makefile: 7,138; javascript: 1,852; lisp: 811; sh: 657; php: 573; python: 387; perl: 365
file content (118 lines) | stat: -rw-r--r-- 2,541 bytes parent folder | download | duplicates (8)
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
(*
** for testing [libats/deqarray]
*)

(* ****** ****** *)
//
// Author: Hongwei Xi
// Authoremail: hwxi AT cs DOT bu DOT edu
// Start time: September, 2013
//
(* ****** ****** *)
//
#include
"share/atspre_staload.hats"
//
(* ****** ****** *)

staload "libats/SATS/deqarray.sats"
staload _(*anon*) = "libats/DATS/deqarray.dats"

(* ****** ****** *)

val () =
{
//
val M = i2sz(2)
//
val deq = deqarray_make_cap<int> (M)
//
val () = assertloc (deqarray_get_size (deq) = 0)
val () = assertloc (deqarray_get_capacity (deq) = M)
//
val () = deqarray_insert_atbeg (deq, 0)
val-(0) = deqarray_takeout_atbeg (deq)
val () = assertloc (deqarray_get_size (deq) = 0)
//
val-~None_vt() = deqarray_insert_atbeg_opt (deq, 1)
val-~None_vt() = deqarray_insert_atbeg_opt (deq, 2)
//
val-~Some_vt(3) = deqarray_insert_atbeg_opt (deq, 3)
//
val-~Some_vt(2) = deqarray_takeout_atbeg_opt (deq)
val-~Some_vt(1) = deqarray_takeout_atbeg_opt (deq)
val-~None_vt((*void*)) = deqarray_takeout_atbeg_opt (deq)
//
val () = assertloc (deqarray_get_size (deq) = 0)
//
val () = deqarray_free_nil (deq)
//
} (* end of [val] *)

(* ****** ****** *)

val () =
{
//
val M = i2sz(2)
//
val deq = deqarray_make_cap<int> (M)
//
val () = assertloc (deqarray_get_size (deq) = 0)
val () = assertloc (deqarray_get_capacity (deq) = M)
//
val () = deqarray_insert_atend (deq, 0)
val-(0) = deqarray_takeout_atend (deq)
val () = assertloc (deqarray_get_size (deq) = 0)
//
val-~None_vt() = deqarray_insert_atend_opt (deq, 1)
val-~None_vt() = deqarray_insert_atend_opt (deq, 2)
//
val-~Some_vt(3) = deqarray_insert_atend_opt (deq, 3)
//
val-~Some_vt(2) = deqarray_takeout_atend_opt (deq)
val-~Some_vt(1) = deqarray_takeout_atend_opt (deq)
val-~None_vt((*void*)) = deqarray_takeout_atend_opt (deq)
//
val () = assertloc (deqarray_get_size (deq) = 0)
//
val () = deqarray_free_nil (deq)
//
} (* end of [val] *)

(* ****** ****** *)

val () =
{
//
val M = i2sz(3)
//
val deq = deqarray_make_cap<int> (M)
//
val () = deqarray_insert_atend (deq, 0)
val () = deqarray_insert_atend (deq, 1)
//
val-(0) = deqarray_takeout_atbeg (deq)
//
val () = deqarray_insert_atend (deq, 2)
val () = deqarray_insert_atend (deq, 3)
//
val-(3) = deqarray_get_at (deq, i2sz(2))
//
val-(1) = deqarray_takeout_atbeg (deq)
val-(2) = deqarray_takeout_atbeg (deq)
val-(3) = deqarray_takeout_atbeg (deq)
//
val () = assertloc (deqarray_get_size (deq) = 0)
//
val () = deqarray_free_nil (deq)
//
} (* end of [val] *)

(* ****** ****** *)

implement main0 () = ()

(* ****** ****** *)

(* end of [libats_deqarray.dats] *)