sig
type 'a t
module type Enumerable =
sig
type 'a enumerable
val enum : 'a BatEnum.Enumerable.enumerable -> 'a BatEnum.t
val of_enum : 'a BatEnum.t -> 'a BatEnum.Enumerable.enumerable
end
type 'a enumerable = 'a t
val enum : 'a enumerable -> 'a t
val of_enum : 'a t -> 'a enumerable
type 'a mappable = 'a t
val map : ('a -> 'b) -> 'a mappable -> 'b mappable
val iter : ('a -> unit) -> 'a BatEnum.t -> unit
val iter2 : ('a -> 'b -> unit) -> 'a BatEnum.t -> 'b BatEnum.t -> unit
val exists : ('a -> bool) -> 'a BatEnum.t -> bool
val for_all : ('a -> bool) -> 'a BatEnum.t -> bool
val fold : ('a -> 'b -> 'a) -> 'a -> 'b BatEnum.t -> 'a
val reduce : ('a -> 'a -> 'a) -> 'a BatEnum.t -> 'a
val fold2 :
('a -> 'b -> 'c -> 'c) -> 'c -> 'a BatEnum.t -> 'b BatEnum.t -> 'c
val scanl : ('a -> 'b -> 'a) -> 'a -> 'b BatEnum.t -> 'a BatEnum.t
val scan : ('a -> 'a -> 'a) -> 'a BatEnum.t -> 'a BatEnum.t
val iteri : (int -> 'a -> unit) -> 'a BatEnum.t -> unit
val iter2i :
(int -> 'a -> 'b -> unit) -> 'a BatEnum.t -> 'b BatEnum.t -> unit
val foldi : (int -> 'a -> 'b -> 'b) -> 'b -> 'a BatEnum.t -> 'b
val fold2i :
(int -> 'a -> 'b -> 'c -> 'c) -> 'c -> 'a BatEnum.t -> 'b BatEnum.t -> 'c
val find : ('a -> bool) -> 'a BatEnum.t -> 'a
val is_empty : 'a BatEnum.t -> bool
val peek : 'a BatEnum.t -> 'a option
val get : 'a BatEnum.t -> 'a option
val push : 'a BatEnum.t -> 'a -> unit
val junk : 'a BatEnum.t -> unit
val clone : 'a BatEnum.t -> 'a BatEnum.t
val force : 'a BatEnum.t -> unit
val take : int -> 'a BatEnum.t -> 'a BatEnum.t
val drop : int -> 'a BatEnum.t -> unit
val skip : int -> 'a BatEnum.t -> 'a BatEnum.t
val take_while : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val drop_while : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val span : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t * 'a BatEnum.t
val break : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t * 'a BatEnum.t
val group : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t BatEnum.t
val clump :
int -> ('a -> unit) -> (unit -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val map : ('a -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val mapi : (int -> 'a -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val filter : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val filter_map : ('a -> 'b option) -> 'a BatEnum.t -> 'b BatEnum.t
val append : 'a BatEnum.t -> 'a BatEnum.t -> 'a BatEnum.t
val prefix_action : (unit -> unit) -> 'a BatEnum.t -> 'a BatEnum.t
val suffix_action : (unit -> unit) -> 'a BatEnum.t -> 'a BatEnum.t
val concat : 'a BatEnum.t BatEnum.t -> 'a BatEnum.t
val flatten : 'a BatEnum.t BatEnum.t -> 'a BatEnum.t
exception No_more_elements
exception Infinite_enum
val empty : unit -> 'a BatEnum.t
val make :
next:(unit -> 'a) ->
count:(unit -> int) -> clone:(unit -> 'a BatEnum.t) -> 'a BatEnum.t
val from : (unit -> 'a) -> 'a BatEnum.t
val from_while : (unit -> 'a option) -> 'a BatEnum.t
val from_loop : 'a -> ('a -> 'b * 'a) -> 'b BatEnum.t
val seq : 'a -> ('a -> 'a) -> ('a -> bool) -> 'a BatEnum.t
val unfold : 'a -> ('a -> ('b * 'a) option) -> 'b BatEnum.t
val init : int -> (int -> 'a) -> 'a BatEnum.t
val singleton : 'a -> 'a BatEnum.t
val repeat : ?times:int -> 'a -> 'a BatEnum.t
val cycle : ?times:int -> 'a BatEnum.t -> 'a BatEnum.t
val delay : (unit -> 'a BatEnum.t) -> 'a BatEnum.t
val to_object :
'a BatEnum.t -> (< clone : 'b; count : int; next : 'a > as 'b)
val of_object :
(< clone : 'a; count : int; next : 'b > as 'a) -> 'b BatEnum.t
val enum : 'a BatEnum.t -> 'a BatEnum.t
val of_enum : 'a BatEnum.t -> 'a BatEnum.t
val count : 'a BatEnum.t -> int
val fast_count : 'a BatEnum.t -> bool
val hard_count : 'a BatEnum.t -> int
val range : ?until:int -> int -> int BatEnum.t
val ( -- ) : int -> int -> int BatEnum.t
val ( --^ ) : int -> int -> int BatEnum.t
val ( --. ) : float * float -> float -> float BatEnum.t
val ( --- ) : int -> int -> int BatEnum.t
val ( --~ ) : char -> char -> char BatEnum.t
val ( // ) : 'a BatEnum.t -> ('a -> bool) -> 'a BatEnum.t
val ( /@ ) : 'a BatEnum.t -> ('a -> 'b) -> 'b BatEnum.t
val ( @/ ) : ('a -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val dup : 'a BatEnum.t -> 'a BatEnum.t * 'a BatEnum.t
val combine : 'a BatEnum.t * 'b BatEnum.t -> ('a * 'b) BatEnum.t
val uncombine : ('a * 'b) BatEnum.t -> 'a BatEnum.t * 'b BatEnum.t
val merge :
('a -> 'a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t -> 'a BatEnum.t
val uniq : 'a BatEnum.t -> 'a BatEnum.t
val compare : ('a -> 'a -> int) -> 'a BatEnum.t -> 'a BatEnum.t -> int
val switch : ('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t * 'a BatEnum.t
val while_do :
('a -> bool) ->
('a BatEnum.t -> 'a BatEnum.t) -> 'a BatEnum.t -> 'a BatEnum.t
module WithMonad :
functor (Mon : BatMonad.S) ->
sig
type 'a m = 'a Mon.m
val sequence :
'a BatEnum.WithMonad.m BatEnum.t ->
'a BatEnum.t BatEnum.WithMonad.m
val fold_monad :
('a -> 'b -> 'a BatEnum.WithMonad.m) ->
'a -> 'b BatEnum.t -> 'a BatEnum.WithMonad.m
end
module Monad :
sig
type 'a m = 'a BatEnum.t
val return : 'a -> 'a BatEnum.Monad.m
val bind :
'a BatEnum.Monad.m ->
('a -> 'b BatEnum.Monad.m) -> 'b BatEnum.Monad.m
end
val print :
?first:string ->
?last:string ->
?sep:string ->
('a BatInnerIO.output -> 'b -> unit) ->
'a BatInnerIO.output -> 'b BatEnum.t -> unit
val t_printer : 'a BatValue_printer.t -> 'a BatEnum.t BatValue_printer.t
module Exceptionless :
sig val find : ('a -> bool) -> 'a BatEnum.t -> 'a option end
module Labels :
sig
val iter : f:('a -> unit) -> 'a BatEnum.t -> unit
val iter2 :
f:('a -> 'b -> unit) -> 'a BatEnum.t -> 'b BatEnum.t -> unit
val exists : f:('a -> bool) -> 'a BatEnum.t -> bool
val for_all : f:('a -> bool) -> 'a BatEnum.t -> bool
val fold : f:('a -> 'b -> 'a) -> init:'a -> 'b BatEnum.t -> 'a
val fold2 :
f:('a -> 'b -> 'c -> 'c) ->
init:'c -> 'a BatEnum.t -> 'b BatEnum.t -> 'c
val iteri : f:(int -> 'a -> unit) -> 'a BatEnum.t -> unit
val iter2i :
f:(int -> 'a -> 'b -> unit) -> 'a BatEnum.t -> 'b BatEnum.t -> unit
val foldi : f:(int -> 'a -> 'b -> 'b) -> init:'b -> 'a BatEnum.t -> 'b
val fold2i :
f:(int -> 'a -> 'b -> 'c -> 'c) ->
init:'c -> 'a BatEnum.t -> 'b BatEnum.t -> 'c
val find : f:('a -> bool) -> 'a BatEnum.t -> 'a
val take_while : f:('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val drop_while : f:('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val map : f:('a -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val mapi : f:(int -> 'a -> 'b) -> 'a BatEnum.t -> 'b BatEnum.t
val filter : f:('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t
val filter_map : f:('a -> 'b option) -> 'a BatEnum.t -> 'b BatEnum.t
val from : f:(unit -> 'a) -> 'a BatEnum.t
val from_while : f:(unit -> 'a option) -> 'a BatEnum.t
val from_loop : init:'a -> f:('a -> 'b * 'a) -> 'b BatEnum.t
val seq : init:'a -> f:('a -> 'a) -> cnd:('a -> bool) -> 'a BatEnum.t
val unfold : init:'a -> f:('a -> ('b * 'a) option) -> 'b BatEnum.t
val init : int -> f:(int -> 'a) -> 'a BatEnum.t
val switch :
f:('a -> bool) -> 'a BatEnum.t -> 'a BatEnum.t * 'a BatEnum.t
val compare :
?cmp:('a -> 'a -> int) -> 'a BatEnum.t -> 'a BatEnum.t -> int
module LExceptionless :
sig val find : f:('a -> bool) -> 'a BatEnum.t -> 'a option end
end
val iapp : 'a BatEnum.t -> 'a BatEnum.t -> 'a BatEnum.t
val icons : 'a -> 'a BatEnum.t -> 'a BatEnum.t
val ising : 'a -> 'a BatEnum.t
val lapp : (unit -> 'a BatEnum.t) -> 'a BatEnum.t -> 'a BatEnum.t
val lcons : (unit -> 'a) -> 'a BatEnum.t -> 'a BatEnum.t
val lsing : (unit -> 'a) -> 'a BatEnum.t
val slazy : (unit -> 'a BatEnum.t) -> 'a BatEnum.t
end