File: cf_map.mli

package info (click to toggle)
pagodacf 0.8-1
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 1,200 kB
  • ctags: 2,331
  • sloc: ml: 8,698; ansic: 3,334; makefile: 178
file content (235 lines) | stat: -rw-r--r-- 10,383 bytes parent folder | download | duplicates (7)
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
(*---------------------------------------------------------------------------*
  INTERFACE  cf_map.mli

  Copyright (c) 2004-2006, James H. Woodyatt
  All rights reserved.

  Redistribution and use in source and binary forms, with or without
  modification, are permitted provided that the following conditions
  are met:

    Redistributions of source code must retain the above copyright
    notice, this list of conditions and the following disclaimer.

    Redistributions in binary form must reproduce the above copyright
    notice, this list of conditions and the following disclaimer in
    the documentation and/or other materials provided with the
    distribution

  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  OF THE POSSIBILITY OF SUCH DAMAGE. 
 *---------------------------------------------------------------------------*)

(** A module type for associative array implementations (with functional
    enhancements over the {!Map} module in the standard library).
*)

(** {6 Overview}
    
    This module defines the common interface to the various implementations of
    functional associative arrays in the {!Cf} library.
*)

module type T = sig    
    (** The tree type. *)
    type +'a t
    
    (** A module defining the type of the key.  Some map implementations may
        define more functions in this module for disambiguating keys from one
        another.
    *)
    module Key: sig type t end
            
    (** The empty tree. *)
    val nil: 'a t
    
    (** Use [empty m] to test whether the tree [m] is empty. *)
    val empty: 'a t -> bool
    
    (** Use [size m] to count the number of elements in the tree [m]. *)
    val size: 'a t -> int
    
    (** Use [min m] to obtain the key-value pair with the ordinally minimum key
        in the tree [m].  Raises [Not_found] if the tree is empty.
    *)
    val min: 'a t -> (Key.t * 'a)
    
    (** Use [max m] to obtain the key-value pair with the ordinally maximum key
        in the tree [m].  Raises [Not_found] if the tree is empty.
    *)
    val max: 'a t -> (Key.t * 'a)
    
    (** Use [search k m] to obtain the value associated with the key [k] in the
        tree [m].  Raise [Not_found] if the tree does not contain the key.
    *)
    val search: Key.t -> 'a t -> 'a
    
    (** Use [member k m] to test whether the tree [m] contains the key [k]. *)
    val member: Key.t -> 'a t -> bool

    (** Use [insert p m] to insert the key-value pair [p] into the tree [m],
        producing a new tree with the inserted element and, if the key [k] is
        already present in [m], the value replaced by the insertion.
    *)
    val insert: (Key.t * 'a) -> 'a t -> 'a t * 'a option
    
    (** Use [replace p m] to obtain a new tree produced by inserting the
        key-value pair [p] into the tree [m], replacing any existing pair
        associated to the same key.
    *)
    val replace: (Key.t * 'a) -> 'a t -> 'a t
    
    (** Use [modify k f m] to obtain a new tree produced by replacing the value
        in the tree [m] associated with the key [k] with the result of applying
        it to the continuation function [f].  Raises [Not_found] if the tree
        does not contain the key.
    *)
    val modify: Key.t -> ('a -> 'a) -> 'a t -> 'a t
    
    (** Use [extract k m] to obtain the value associated with the key [k] in
        the tree [m] and a new tree with the key deleted from the tree.  Raises
        [Not_found] if the tree does not contain the key.
    *)
    val extract: Key.t -> 'a t -> 'a * 'a t
    
    (** Use [delete k m] to obtain a new tree produced by deleting the key [k]
        from the tree [m].  If the tree does not contain the key, then the
        function simply returns its argument.
    *)
    val delete: Key.t -> 'a t -> 'a t
    
    (** Use [of_list s] to compose a tree by iterating the list of key-value
        pairs [s] and inserting them in order into a new tree.
    *)
    val of_list: (Key.t * 'a) list -> 'a t
    
    (** Use [of_list_incr s] to compose a tree with the key-value pairs in the
        ordered list [s].  Runs in linear time if the keys in the list [s] are
        known to be in increasing order.  Otherwise, there is an additional
        linear cost beyond [of_list s].
    *)
    val of_list_incr: (Key.t * 'a) list -> 'a t
    
    (** Use [of_list_decr s] to compose a tree with the key-value pairs in the
        ordered list [s].  Runs in linear time if the keys in the list [s] are
        known to be in decreasing order.  Otherwise, there is an additional
        linear cost beyond [of_list s].
    *)
    val of_list_decr: (Key.t * 'a) list -> 'a t
    
    (** Use [of_seq z] to compose a tree by evaluating the entire sequence of
        key-value pairs [z] and inserting them in order into a new tree.
    *)
    val of_seq: (Key.t * 'a) Cf_seq.t -> 'a t
    
    (** Use [of_seq_incr z] to compose a tree with the key-value pairs in the
        ordered sequence [z].  Runs in linear time if the keys in the sequence
        [z] are known to be in increasing order.  Otherwise, there is an
        additional linear cost beyond [of_seq z].
    *)
    val of_seq_incr: (Key.t * 'a) Cf_seq.t -> 'a t
    
    (** Use [of_seq_decr z] to compose a tree with the key-value pairs in the
        ordered sequence [z].  Runs in linear time if the keys in the sequence
        [z] are known to be in decreasing order.  Otherwise, there is an
        additional linear cost beyond [of_seq z].
    *)
    val of_seq_decr: (Key.t * 'a) Cf_seq.t -> 'a t

    (** Use [to_list_incr m] to obtain a sequence of the key-value pairs in the
        tree [m] in order of increasing ordinality.
    *)
    val to_list_incr: 'a t -> (Key.t * 'a) list

    (** Use [to_list_decr m] to obtain a sequence of the key-value pairs in the
        tree [m] in order of descreasing ordinality.
    *)
    val to_list_decr: 'a t -> (Key.t * 'a) list

    (** Use [to_seq_incr m] to obtain a sequence of the key-value pairs in the
        tree [m] in order of increasing ordinality.
    *)
    val to_seq_incr: 'a t -> (Key.t * 'a) Cf_seq.t

    (** Use [to_seq_decr m] to obtain a sequence of the key-value pairs in the
        tree [m] in order of descreasing ordinality.
    *)
    val to_seq_decr: 'a t -> (Key.t * 'a) Cf_seq.t

    (** Use [nearest_decr k m] to obtain the key-value pair ordinally less than
        or equal to the key [k] in the map [m].  Raises [Not_found] if the map
        is empty or all the keys are ordinally greater.
    *)
    val nearest_decr: Key.t -> 'a t -> (Key.t * 'a) Cf_seq.t
    
    (** Use [nearest_incr k m] to obtain the key-value pair ordinally greater
        than or equal to the key [k] in the map [m].  Raises [Not_found] if the
        map is empty or all the keys are ordinally less.
    *)
    val nearest_incr: Key.t -> 'a t -> (Key.t * 'a) Cf_seq.t
    
    (** Use [iterate f m] to apply the function [f] to each key-value pair in
        the tree [m] in an arbitrary order (not increasing or decreasing).
    *)
    val iterate: ((Key.t * 'a) -> unit) -> 'a t -> unit
    
    (** Use [predicate f m] to test whether all the key-value pairs in the tree
        [m] satisfy the predicate function [f].  The nodes of the tree are
        visited in an arbitrary order (not increasing or decreasing).
    *)
    val predicate: ((Key.t * 'a) -> bool) -> 'a t -> bool

    (** Use [fold f s m] to fold the every key-value pair in the tree [m] into
        the state [s] with the folding function [f], visiting the elements in
        an arbitrary order (not increasing or decreasing).  Runs in O(log N)
        space, i.e. not tail-recursive.
    *)
    val fold: ('b -> (Key.t * 'a) -> 'b) -> 'b -> 'a t -> 'b
    
    (** Use [filter f m] to obtain a new tree comprised of all the key-value
        pairs in the tree [m] that satisfy the filtering function [f].  The
        elements in [m] are visited in arbitrary order (not increasing or
        decreasing).  Runs in O(log N) space, i.e. not tail-recursive.
    *)
    val filter: ((Key.t * 'a) -> bool) -> 'a t -> 'a t
    
    (** Use [map f m] to obtain a new tree produced by applying the mapping
        function [f] to the key and the value of each key-value pair in the
        tree [m] and associating the resulting value to the key in the new
        tree.  Elements in the tree are visited in arbitrary order (not
        increasing or descreasing.  Runs in O(log N) space, i.e. not
        tail-recursive.
    *)
    val map: ((Key.t * 'a) -> 'b) -> 'a t -> 'b t
    
    (** Use [optmap f m] to obtain a new tree produced by applying the mapping
        function [f] to the key and the value of each key-value pair in the
        tree [m] and associating the resulting value to the key in the new
        tree.  If the function [f] returns [None] then no value for that key
        will be present in the new tree.  Elements in the tree are visited in
        arbitrary order (not increasing or descreasing.  Runs in O(log N)
        space, i.e. not tail-recursive.
    *)
    val optmap: ((Key.t * 'a) -> 'b option) -> 'a t -> 'b t
    
    (** Use [partition f m] to obtain a pair of new trees produced by applying
        the partitioning function [f] to all the elements in the tree [m] in an
        arbitrary order (not increasing or descreasing).  The first tree will
        contain all the elements for which [f] returns [true], and the second
        tree will have all the elements for which [f] returns [false].  Runs in
        O(log N) space, i.e. not tail-recursive.
    *)
    val partition: ((Key.t * 'a) -> bool) -> 'a t -> 'a t * 'a t
end

(*--- End of File [ cf_map.mli ] ---*)