module BatList:Additional and modified functions for lists.sig..end
The OCaml standard library provides a module for list functions. This BatList module can be used to extend the List module or as a standalone module. It provides new functions and modify the behavior of some other ones (in particular all functions are now tail-recursive).
The following functions have the same behavior as the List
module ones but are tail-recursive: map, append, concat,
flatten, fold_right, remove_assoc, remove_assq,
split. That means they will not
cause a Stack_overflow when used on very long list.
The implementation might be a little more slow in bytecode, but compiling in native code will not affect performances.
This module extends Stdlib's
List
module, go there for documentation on the rest of the functions
and types.
type'at ='a list
The type of lists
Author(s): Xavier Leroy (base module), Brian Hurt, Nicolas Cannasse, Richard W.M. Jones, David Teller
include BatEnum.Enumerable
include BatInterfaces.Mappable
val is_empty : 'a list -> boolis_empty e returns true if e does not contains any element.val cons : 'a -> 'a list -> 'a listcons h t returns the list starting with h and continuing as tval first : 'a list -> 'aEmpty_list if
the list is empty (similar to hd).val last : 'a list -> 'aEmpty_list if
the list is empty. This function takes linear time.val at : 'a list -> int -> 'aat l n returns the n-th element of the list l or raise
Invalid_index is the index is outside of l bounds.val append : 'a list -> 'a list -> 'a list@.
Tail-recursive (length of the first argument).val concat : 'a list list -> 'a listval flatten : 'a list list -> 'a listconcat.val make : int -> 'a -> 'a listString.make, make n x returns a
list containing n elements x.val init : int -> (int -> 'a) -> 'a listArray.init, init n f returns the list containing
the results of (f 0),(f 1).... (f (n-1)).
Raise Invalid_arg "BatList.init" if n < 0.val iteri : (int -> 'a -> 'b) -> 'a list -> unititeri f l will call (f 0 a0);(f 1 a1) ... (f n an) where
a0..an are the elements of the list l.val map : ('a -> 'b) -> 'a list -> 'b listmap f [a1; ...; an] applies function f to a1, ..., an,
and builds the list [f a1; ...; f an]
with the results returned by f. Tail-recursive.val mapi : (int -> 'a -> 'b) -> 'a list -> 'b listmapi f l will build the list containing
(f 0 a0);(f 1 a1) ... (f n an) where a0..an are the elements of
the list l.val fold_right : ('a -> 'b -> 'b) -> 'a list -> 'b -> 'bList.fold_right f [a1; ...; an] b is
f a1 (f a2 (... (f an b) ...)). Tail-recursive.val reduce : ('a -> 'a -> 'a) -> 'a list -> 'aList.reduce f h::t is fold_left f h t.Empty_list on empty lists.val max : 'a list -> 'amax l returns the largest value in l as judged by
Pervasives.compareval min : 'a list -> 'amin l returns the smallest value in l as judged by
Pervasives.compareval sum : int list -> intsum l returns the sum of the elements of lval fsum : float list -> floatsum l returns the sum of the elements of lval iter2 : ('a -> 'b -> unit) -> 'a list -> 'b list -> unitList.iter2 f [a1; ...; an] [b1; ...; bn] calls in turn
f a1 b1; ...; f an bn.Different_list_size if the two lists have
different lengths.val map2 : ('a -> 'b -> 'c) -> 'a list -> 'b list -> 'c listList.map2 f [a1; ...; an] [b1; ...; bn] is
[f a1 b1; ...; f an bn].Different_list_size if the two lists have
different lengths. Tail-recursive.val fold_left2 : ('a -> 'b -> 'c -> 'a) -> 'a -> 'b list -> 'c list -> 'aList.fold_left2 f a [b1; ...; bn] [c1; ...; cn] is
f (... (f (f a b1 c1) b2 c2) ...) bn cn.Different_list_size if the two lists have
different lengths.val fold_right2 : ('a -> 'b -> 'c -> 'c) -> 'a list -> 'b list -> 'c -> 'cList.fold_right2 f [a1; ...; an] [b1; ...; bn] c is
f a1 b1 (f a2 b2 (... (f an bn c) ...)).Different_list_size if the two lists have
different lengths. Tail-recursive.val for_all2 : ('a -> 'b -> bool) -> 'a list -> 'b list -> boolList.for_all, but for a two-argument predicate.Invalid_argument if the two lists have
different lengths.val exists2 : ('a -> 'b -> bool) -> 'a list -> 'b list -> boolList.exists, but for a two-argument predicate.Invalid_argument if the two lists have
different lengths.val find_exn : ('a -> bool) -> exn -> 'a list -> 'afind_exn p e l returns the first element of l such as p x
returns true or raises e if such an element has not been found.val findi : (int -> 'a -> bool) -> 'a list -> int * 'afindi p e l returns the first element ai of l along with its
index i such that p i ai is true, or raises Not_found if no
such element has been found.val find_map : ('a -> 'b option) -> 'a list -> 'bfind_map pred list finds the first element of list for which
pred element returns Some r. It returns r immediately
once found or raises Not_found if no element matches the
predicate. See also BatList.filter_map.val rfind : ('a -> bool) -> 'a list -> 'arfind p l returns the last element x of l such as p x returns
true or raises Not_found if such element as not been found.val filter : ('a -> bool) -> 'a list -> 'a listfilter p l returns all the elements of the list l
that satisfy the predicate p. The order of the elements
in the input list is preserved.val filter_map : ('a -> 'b option) -> 'a list -> 'b listfilter_map f l calls (f a0) (f a1).... (f an) where a0..an are
the elements of l. It returns the list of elements bi such as
f ai = Some bi (when f returns None, the corresponding element of
l is discarded).val find_all : ('a -> bool) -> 'a list -> 'a listfind_all is another name for List.filter.val partition : ('a -> bool) -> 'a list -> 'a list * 'a listpartition p l returns a pair of lists (l1, l2), where
l1 is the list of all the elements of l that
satisfy the predicate p, and l2 is the list of all the
elements of l that do not satisfy p.
The order of the elements in the input list is preserved.val index_of : 'a -> 'a list -> int optionindex_of e l returns the index of the first occurrence of e
in l, or None if there is no occurrence of e in lval index_ofq : 'a -> 'a list -> int optionindex_ofq e l behaves as index_of e l except it uses
physical equalityval rindex_of : 'a -> 'a list -> int optionrindex_of e l returns the index of the last occurrence of e
in l, or None if there is no occurrence of e in lval rindex_ofq : 'a -> 'a list -> int optionrindex_ofq e l behaves as rindex_of e l except it uses
physical equalityval unique : ?cmp:('a -> 'a -> bool) -> 'a list -> 'a listunique cmp l returns the list l without any duplicate element.
Default comparator ( = ) is used if no comparison function specified.
This function takes O(n²) time.
See also sort_unique to save time in cases when reordering the list is acceptable
val assoc_inv : 'a -> ('b * 'a) list -> 'bassoc_inv b l returns the key associated with value b in the list of
pairs l. That is,
assoc b [ ...; (a,b); ...] = a
if (a,b) is the leftmost binding of a in list l.
Raise Not_found if there is no key associated with b in the
list l.val remove_assoc : 'a -> ('a * 'b) list -> ('a * 'b) listremove_assoc a l returns the list of
pairs l without the first pair with key a, if any.
Tail-recursive.val remove_assq : 'a -> ('a * 'b) list -> ('a * 'b) listList.remove_assoc, but uses physical equality instead
of structural equality to compare keys. Tail-recursive.val split_at : int -> 'a list -> 'a list * 'a listsplit_at n l returns two lists l1 and l2, l1 containing the
first n elements of l and l2 the others. Raise Invalid_index if
n is outside of l size bounds.val split_nth : int -> 'a list -> 'a list * 'a listsplit_at.val remove : 'a list -> 'a -> 'a listremove l x returns the list l without the first element x found
or returns l if no element is equal to x. Elements are compared
using ( = ).val remove_if : ('a -> bool) -> 'a list -> 'a listremove_if cmp l is similar to remove, but with cmp used
instead of ( = ).val remove_all : 'a list -> 'a -> 'a listremove_all l x is similar to remove but removes all elements that
are equal to x and not only the first one.val take : int -> 'a list -> 'a listtake n l returns up to the n first elements from list l, if
available.val drop : int -> 'a list -> 'a listdrop n l returns l without the first n elements, or the empty
list if l have less than n elements.val take_while : ('a -> bool) -> 'a list -> 'a listtakewhile f xs returns the first elements of list xs
which satisfy the predicate f.val drop_while : ('a -> bool) -> 'a list -> 'a listdropwhile f xs returns the list xs with the first
elements satisfying the predicate f dropped.val interleave : ?first:'a -> ?last:'a -> 'a -> 'a list -> 'a listinterleave ~first ~last sep [a1;a2;a3;...;an] returns
first; a1; sep; a2; sep; a3; sep; ...; sep; an
Abstraction layer.
val enum : 'a list -> 'a BatEnum.tval of_enum : 'a BatEnum.t -> 'a listval backwards : 'a list -> 'a BatEnum.tval of_backwards : 'a BatEnum.t -> 'a listval split : ('a * 'b) list -> 'a list * 'b listsplit [(a1,b1); ...; (an,bn)] is ([a1; ...; an], [b1; ...; bn]).
Tail-recursive.val combine : 'a list -> 'b list -> ('a * 'b) listcombine [a1; ...; an] [b1; ...; bn] is
[(a1,b1); ...; (an,bn)].Different_list_size if the two lists
have different lengths. Tail-recursive.val make_compare : ('a -> 'a -> int) -> 'a list -> 'a list -> intmake_compare c generates the lexicographical order on lists
induced by cval sort : ?cmp:('a -> 'a -> int) -> 'a list -> 'a listcompare).val sort_unique : ('a -> 'a -> int) -> 'a list -> 'a listsort_unique cmp l returns the list l sorted and without any duplicate element. cmp is a usual comparison function providing linear order.
This function takes O(n log n) time.
val group : ('a -> 'a -> int) -> 'a list -> 'a list listgroup cmp l returns list of groups and each group consists of elements judged equal by comparison function cmp. Groups in the resulting list appear in order given by cmp. All groups are always nonempty. group returns [] only if l is empty.
For example group cmp [f;c;b;e;d;a] can give [[a;b];[c];[d;e;f]] if following conditions are met:
cmp a b = 0, cmp b c = -1, cmp c d = -1, cmp d e = 0,...
val cartesian_product : 'a list -> 'b list -> ('a * 'b) listList.combine, this returns every pair
of elements formed out of the two lists. cartesian_product
[a1; ...; an] [b1; ...; bn] = [(a1,b1);(a1,b2); ...;
(a1,bn); (a2,b1); ...; (an,bn)]. The lists can be of
unequal size.val n_cartesian_product : 'a list list -> 'a list list[a;b];[c];[d;e;f], returns
[a;c;d];[a;c;e];[a;c;f];[b;c;d];[b;c;e];[b;c;f], all
ways of choosing one element from each input list.val print : ?first:string ->
?last:string ->
?sep:string ->
('a BatInnerIO.output -> 'b -> unit) ->
'a BatInnerIO.output -> 'b list -> unitval sprint : ?first:string ->
?last:string ->
?sep:string -> ('a BatInnerIO.output -> 'b -> unit) -> 'b list -> stringval t_printer : 'a BatValue_printer.t -> 'a t BatValue_printer.tval nth : 'a list -> int -> 'aat.val takewhile : ('a -> bool) -> 'a list -> 'a listBatList.take_whileval dropwhile : ('a -> bool) -> 'a list -> 'a listBatList.drop_whileList with functions
behaving slightly differently but having the same name. This is by design:
the functions meant to override the corresponding functions of List.module Exceptionless:sig..end
module Labels:sig..end
List with labels.
val (@) : 'a list -> 'a list -> 'a listList.append.