Make.ListThe Monad.Collection.S interface for lists
val all : 'a T1(T)(M).t list -> 'a list T1(T)(M).tall cs performs all computations in cs and returns a list of results in the same order. The order of evaluation is unspecified.
val all_ignore : 'a T1(T)(M).t list -> unit T1(T)(M).tall_ignore cs performs all computations in cs in an unspecified order, and discards the results.
val sequence : unit T1(T)(M).t list -> unit T1(T)(M).tsequence cs performs all computations in cs from left to right.
val map : 'a list -> f:('a -> 'b T1(T)(M).t) -> 'b list T1(T)(M).tmap xs ~f returns a container where n'th element is a result of computation f x_n, where x_n is the n'th element of the input container. It is unspecified, in which order the computations are evaluated, and whether all computations are performed.
val iter : 'a list -> f:('a -> unit T1(T)(M).t) -> unit T1(T)(M).titer xs ~f performs f x for each x in xs in the left to right order.
val fold : 'a list -> init:'b -> f:('b -> 'a -> 'b T1(T)(M).t) -> 'b T1(T)(M).tfold xs ~init:s0 ~f folds f over xs in the given monad.
Effectively computes a chain:
f s0 x0 >>= fun s1 ->
f s1 x1 >>= fun s2 ->
...
f sN xNExcept that the computation uses a constant stack size.
val fold_left :
'a list ->
init:'b ->
f:('b -> 'a -> 'b T1(T)(M).t) ->
'b T1(T)(M).tfold_left is a synonym for fold.
val fold_right :
'a list ->
f:('a -> 'b -> 'b T1(T)(M).t) ->
init:'b ->
'b T1(T)(M).tfold_right xs ~f ~init:s0 folds f over xs from right to left in the given monad.
Effectively computes a chain:
f x_N s0 >>= fun s1 ->
f x_(N-1) s1 >>= fun s2 ->
...
f x0 s_NExcept that the computation uses a constant stack size.
val reduce : 'a list -> f:('a -> 'a -> 'a T1(T)(M).t) -> 'a option T1(T)(M).treduce xs ~f same as fold except that the initial state is obtained from the first element of the container, i.e., computes a sequence
f x0 x1 >>= fun s1 ->
f s1 x2 >>= fun s2 ->
...
f sN xNval exists : 'a list -> f:('a -> bool T1(T)(M).t) -> bool T1(T)(M).texists xs ~f returns a computation that results in true iff there exists an element x in xs such that f x evaluates to true
val for_all : 'a list -> f:('a -> bool T1(T)(M).t) -> bool T1(T)(M).tfor_all xs ~f returns a computation that results in true iff for all x in xs f x evaluates to true.
val count : 'a list -> f:('a -> bool T1(T)(M).t) -> int T1(T)(M).tcount xs ~f returns a computation that results to a number of elements of xs for which f evaluates to true. The order of application of f is unspecified.
val map_reduce :
(module Monoid.S with type t = 'a) ->
'b list ->
f:('b -> 'a T1(T)(M).t) ->
'a T1(T)(M).tmap_reduce (module Monoid) xs ~f a composition of map and reduce. Effectively the same as map xs ~f and then reduce in Monoid except that no intermediate collections are created.
val find : 'a list -> f:('a -> bool T1(T)(M).t) -> 'a option T1(T)(M).tfind xs ~f returns the first element x of xs for which f x evaluates to true.
val find_map :
'a list ->
f:('a -> 'b option T1(T)(M).t) ->
'b option T1(T)(M).tfind_map xs ~f returns the first computation f x for x in xs which will result in non None.
val filter : 'a list -> f:('a -> bool T1(T)(M).t) -> 'a list T1(T)(M).tfilter xs ~f returns a computation that contains all the elements of xs for which f evaluated to true. The order of the elements is the same.
val filter_map :
'a list ->
f:('a -> 'b option T1(T)(M).t) ->
'b list T1(T)(M).tfilter_map xs ~f is a partial mapping from xs to a collection ys, such that all the elements of xs for which f returned Some value are mapped, while the rest are omitted.