sig
type ('a, 'b) t = ('a, 'b) BatArray.Cap.t
constraint 'b = [< `Read | `Write ]
external length : ('a, [< `Read | `Write ]) t -> int = "%array_length"
external get : ('a, [< `Read | `Write > `Read ]) t -> int -> 'a
= "%array_safe_get"
external set : ('a, [< `Read | `Write > `Write ]) t -> int -> 'a -> unit
= "%array_safe_set"
external make : int -> 'a -> ('a, [< `Read | `Write ]) t = "caml_make_vect"
external create : int -> 'a -> ('a, [< `Read | `Write ]) t
= "caml_make_vect"
external of_array : 'a array -> ('a, [< `Read | `Write ]) t = "%identity"
external to_array : ('a, [ `Read | `Write ]) t -> 'a array = "%identity"
external read_only :
('a, [< `Read | `Write > `Read ]) t -> ('a, [ `Read ]) t = "%identity"
external write_only :
('a, [< `Read | `Write > `Write ]) t -> ('a, [ `Write ]) t = "%identity"
val init : int -> (int -> 'a) -> ('a, [< `Read | `Write ]) t
val make_matrix :
int -> int -> 'a -> (('a, [< `Read | `Write ]) t, [< `Read | `Write ]) t
val create_matrix :
int -> int -> 'a -> (('a, [< `Read | `Write ]) t, [< `Read | `Write ]) t
val iter : ('a -> unit) -> ('a, [< `Read | `Write > `Read ]) t -> unit
val map :
('a -> 'b) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
val iteri :
(int -> 'a -> unit) -> ('a, [< `Read | `Write > `Read ]) t -> unit
val mapi :
(int -> 'a -> 'b) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
val modify : ('a -> 'a) -> ('a, [ `Read | `Write ]) t -> unit
val modifyi : (int -> 'a -> 'a) -> ('a, [ `Read | `Write ]) t -> unit
val fold_left :
('a -> 'b -> 'a) -> 'a -> ('b, [< `Read | `Write > `Read ]) t -> 'a
val fold_right :
('b -> 'a -> 'a) -> ('b, [< `Read | `Write > `Read ]) t -> 'a -> 'a
val iter2 :
('a -> 'b -> unit) ->
('a, [< `Read | `Write > `Read ]) t ->
('b, [< `Read | `Write > `Read ]) t -> unit
val iter2i :
(int -> 'a -> 'b -> unit) ->
('a, [< `Read | `Write > `Read ]) t ->
('b, [< `Read | `Write > `Read ]) t -> unit
val for_all : ('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> bool
val exists : ('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> bool
val find : ('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> 'a
val mem : 'a -> ('a, [< `Read | `Write > `Read ]) t -> bool
val memq : 'a -> ('a, [< `Read | `Write > `Read ]) t -> bool
val findi : ('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> int
val filter :
('a -> bool) ->
('a, [< `Read | `Write > `Read ]) t -> ('a, [< `Read | `Write ]) t
val filter_map :
('a -> 'b option) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
val find_all :
('a -> bool) ->
('a, [< `Read | `Write > `Read ]) t -> ('a, [< `Read | `Write ]) t
val partition :
('a -> bool) ->
('a, [< `Read | `Write > `Read ]) t ->
('a, [< `Read | `Write ]) t * ('a, [< `Read | `Write ]) t
val rev :
('a, [< `Read | `Write > `Read ]) t -> ('a, [< `Read | `Write ]) t
val rev_in_place : ('a, [ `Read | `Write ]) t -> unit
val append :
('a, [< `Read | `Write > `Read ]) t ->
('a, [< `Read | `Write > `Read ]) t -> ('a, [< `Read | `Write ]) t
val concat :
('a, [< `Read | `Write > `Read ]) t list -> ('a, [< `Read | `Write ]) t
val sub :
('a, [< `Read | `Write > `Read ]) t ->
int -> int -> ('a, [< `Read | `Write ]) t
val copy : ('a, [< `Read | `Write > `Read ]) t -> 'a array
val fill : ('a, [< `Read | `Write > `Write ]) t -> int -> int -> 'a -> unit
val blit :
('a, [< `Read | `Write > `Read ]) t ->
int -> ('a, [< `Read | `Write > `Write ]) t -> int -> int -> unit
val enum : ('a, [< `Read | `Write > `Read ]) t -> 'a BatEnum.t
val of_enum : 'a BatEnum.t -> ('a, [< `Read | `Write ]) t
val backwards : ('a, [< `Read | `Write > `Read ]) t -> 'a BatEnum.t
val of_backwards : 'a BatEnum.t -> ('a, [< `Read | `Write ]) t
val to_list : ('a, [< `Read | `Write > `Read ]) t -> 'a list
val of_list : 'a list -> ('a, [< `Read | `Write ]) t
val sort : ('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val stable_sort : ('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val fast_sort : ('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val print :
?first:string ->
?last:string ->
?sep:string ->
('a BatIO.output -> 'b -> unit) ->
'a BatIO.output -> ('b, [< `Read | `Write > `Read ]) t -> unit
val compare :
'a BatOrd.comp -> ('a, [< `Read | `Write > `Read ]) t BatOrd.comp
val ord : 'a BatOrd.ord -> ('a, [< `Read | `Write > `Read ]) t BatOrd.ord
val equal : 'a BatOrd.eq -> ('a, [< `Read | `Write > `Read ]) t BatOrd.eq
module Exceptionless :
sig
val find :
('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> 'a option
val findi :
('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> int option
end
module Labels :
sig
val init : int -> f:(int -> 'a) -> ('a, [< `Read | `Write ]) t
val make : int -> init:'a -> ('a, [< `Read | `Write ]) t
val create : int -> init:'a -> ('a, [< `Read | `Write ]) t
val make_matrix :
dimx:int ->
dimy:int ->
'a -> (('a, [< `Read | `Write ]) t, [< `Read | `Write ]) t
val create_matrix :
dimx:int ->
dimy:int ->
'a -> (('a, [< `Read | `Write ]) t, [< `Read | `Write ]) t
val sub :
('a, [< `Read | `Write > `Read ]) t ->
pos:int -> len:int -> ('a, [< `Read | `Write ]) t
val fill :
('a, [< `Read | `Write > `Write ]) t ->
pos:int -> len:int -> 'a -> unit
val blit :
src:('a, [< `Read | `Write > `Read ]) t ->
src_pos:int ->
dst:('a, [< `Read | `Write > `Write ]) t ->
dst_pos:int -> len:int -> unit
val iter :
f:('a -> unit) -> ('a, [< `Read | `Write > `Read ]) t -> unit
val iteri :
f:(int -> 'a -> unit) -> ('a, [< `Read | `Write > `Read ]) t -> unit
val modify : f:('a -> 'a) -> ('a, [ `Read | `Write ]) t -> unit
val modifyi : f:(int -> 'a -> 'a) -> ('a, [ `Read | `Write ]) t -> unit
val fold_left :
f:('a -> 'b -> 'a) ->
init:'a -> ('b, [< `Read | `Write > `Read ]) t -> 'a
val fold_right :
f:('b -> 'a -> 'a) ->
('b, [< `Read | `Write > `Read ]) t -> init:'a -> 'a
val sort : cmp:('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val stable_sort :
cmp:('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val fast_sort :
cmp:('a -> 'a -> int) -> ('a, [ `Read | `Write ]) t -> unit
val iter2 :
f:('a -> 'b -> unit) ->
('a, [< `Read | `Write > `Read ]) t ->
('b, [< `Read | `Write > `Read ]) t -> unit
val iter2i :
f:(int -> 'a -> 'b -> unit) ->
('a, [< `Read | `Write > `Read ]) t ->
('b, [< `Read | `Write > `Read ]) t -> unit
val exists :
f:('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> bool
val for_all :
f:('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> bool
val find : f:('a -> bool) -> ('a, [< `Read | `Write > `Read ]) t -> 'a
val map :
f:('a -> 'b) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
val mapi :
f:(int -> 'a -> 'b) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
val filter :
f:('a -> bool) ->
('a, [< `Read | `Write > `Read ]) t -> ('a, [< `Read | `Write ]) t
val filter_map :
f:('a -> 'b option) ->
('a, [< `Read | `Write > `Read ]) t -> ('b, [< `Read | `Write ]) t
end
external unsafe_get : ('a, [< `Read | `Write > `Read ]) t -> int -> 'a
= "%array_unsafe_get"
external unsafe_set :
('a, [< `Read | `Write > `Write ]) t -> int -> 'a -> unit
= "%array_unsafe_set"
val find :
('a -> bool) ->
('a, [< `Read | `Write > `Read ]) BatArray.Cap.t -> 'a option
val findi :
('a -> bool) ->
('a, [< `Read | `Write > `Read ]) BatArray.Cap.t -> int option
end