sig
type 'a t = 'a BatString.Cap.t
external length : 'a t -> int = "%string_length"
val is_empty : 'a t -> bool
external get : [> `Read ] t -> int -> char = "%string_safe_get"
external set : [> `Write ] t -> int -> char -> unit = "%string_safe_set"
external create : int -> 'a t = "caml_create_string"
external of_string : string -> 'a t = "%identity"
external to_string : [ `Read | `Write ] t -> string = "%identity"
external read_only : [> `Read ] t -> [ `Read ] t = "%identity"
external write_only : [> `Write ] t -> [ `Write ] t = "%identity"
val make : int -> char -> 'a t
val init : int -> (int -> char) -> 'a t
val enum : [> `Read ] t -> char BatEnum.t
val of_enum : char BatEnum.t -> 'a t
val backwards : [> `Read ] t -> char BatEnum.t
val of_backwards : char BatEnum.t -> 'a t
val of_list : char list -> 'a t
val to_list : [> `Read ] t -> char list
val of_int : int -> 'a t
val of_float : float -> 'a t
val of_char : char -> 'a t
val to_int : [> `Read ] t -> int
val to_float : [> `Read ] t -> float
val map : (char -> char) -> [> `Read ] t -> 'a t
val fold_left : ('a -> char -> 'a) -> 'a -> [> `Read ] t -> 'a
val fold_right : (char -> 'a -> 'a) -> [> `Read ] t -> 'a -> 'a
val filter : (char -> bool) -> [> `Read ] t -> 'a t
val filter_map : (char -> char option) -> [> `Read ] t -> 'a t
val iter : (char -> unit) -> [> `Read ] t -> unit
val index : [> `Read ] t -> char -> int
val rindex : [> `Read ] t -> char -> int
val index_from : [> `Read ] t -> int -> char -> int
val rindex_from : [> `Read ] t -> int -> char -> int
val contains : [> `Read ] t -> char -> bool
val contains_from : [> `Read ] t -> int -> char -> bool
val rcontains_from : [> `Read ] t -> int -> char -> bool
val find : [> `Read ] t -> [> `Read ] t -> int
val find_from : [> `Read ] t -> int -> [> `Read ] t -> int
val rfind : [> `Read ] t -> [> `Read ] t -> int
val rfind_from : [> `Read ] t -> int -> [> `Read ] t -> int
val ends_with : [> `Read ] t -> [> `Read ] t -> bool
val starts_with : [> `Read ] t -> [> `Read ] t -> bool
val exists : [> `Read ] t -> [> `Read ] t -> bool
val lchop : ?n:int -> [> `Read ] t -> 'a t
val rchop : ?n:int -> [> `Read ] t -> 'a t
val trim : [> `Read ] t -> 'a t
val quote : [> `Read ] t -> string
val left : [> `Read ] t -> int -> 'a t
val right : [> `Read ] t -> int -> 'a t
val head : [> `Read ] t -> int -> 'a t
val tail : [> `Read ] t -> int -> 'a t
val strip : ?chars:[> `Read ] t -> [> `Read ] t -> 'a t
val uppercase : [> `Read ] t -> 'a t
val lowercase : [> `Read ] t -> 'a t
val capitalize : [> `Read ] t -> 'a t
val uncapitalize : [> `Read ] t -> 'a t
val copy : [> `Read ] t -> 'a t
val sub : [> `Read ] t -> int -> int -> 'a t
val fill : [> `Write ] t -> int -> int -> char -> unit
val blit : [> `Read ] t -> int -> [> `Write ] t -> int -> int -> unit
val concat : [> `Read ] t -> [> `Read ] t list -> 'a t
val escaped : [> `Read ] t -> 'a t
val replace_chars : (char -> [> `Read ] t) -> [> `Read ] t -> 'a t
val replace :
str:[> `Read ] t -> sub:[> `Read ] t -> by:[> `Read ] t -> bool * 'a t
val nreplace :
str:[> `Read ] t -> sub:[> `Read ] t -> by:[> `Read ] t -> 'a t
val repeat : [> `Read ] t -> int -> 'a t
val split : [> `Read ] t -> by:[> `Read ] t -> 'a t * 'b t
val rsplit : [> `Read ] t -> by:string -> string * string
val nsplit : [> `Read ] t -> by:[> `Read ] t -> 'a t list
val splice : [ `Read | `Write ] t -> int -> int -> [> `Read ] t -> string
val join : [> `Read ] t -> [> `Read ] t list -> 'a t
val slice : ?first:int -> ?last:int -> [> `Read ] t -> 'a t
val explode : [> `Read ] t -> char list
val implode : char list -> 'a t
val compare : [> `Read ] t -> [> `Read ] t -> int
val icompare : [> `Read ] t -> [> `Read ] t -> int
val print : 'a BatInnerIO.output -> [> `Read ] t -> unit
val println : 'a BatInnerIO.output -> [> `Read ] t -> unit
val print_quoted : 'a BatInnerIO.output -> [> `Read ] t -> unit
external unsafe_get : [> `Read ] t -> int -> char = "%string_unsafe_get"
external unsafe_set : [> `Write ] t -> int -> char -> unit
= "%string_unsafe_set"
external unsafe_blit :
[> `Read ] t -> int -> [> `Write ] t -> int -> int -> unit
= "caml_blit_string" "noalloc"
external unsafe_fill : [> `Write ] t -> int -> int -> char -> unit
= "caml_fill_string" "noalloc"
module Exceptionless :
sig
val to_int : [> `Read ] t -> int option
val to_float : [> `Read ] t -> float option
val index : [> `Read ] t -> char -> int option
val rindex : [> `Read ] t -> char -> int option
val index_from : [> `Read ] t -> int -> char -> int option
val rindex_from : [> `Read ] t -> int -> char -> int option
val find : [> `Read ] t -> [> `Read ] t -> int option
val find_from : [> `Read ] t -> int -> [> `Read ] t -> int option
val rfind : [> `Read ] t -> [> `Read ] t -> int option
val rfind_from : [> `Read ] t -> int -> [> `Read ] t -> int option
val split : [> `Read ] t -> by:[> `Read ] t -> ('a t * 'b t) option
val rsplit : [> `Read ] t -> by:[> `Read ] t -> ('a t * 'b t) option
end
val to_int : [> `Read ] BatString.Cap.t -> int option
val to_float : [> `Read ] BatString.Cap.t -> float option
val index : [> `Read ] BatString.Cap.t -> char -> int option
val rindex : [> `Read ] BatString.Cap.t -> char -> int option
val index_from : [> `Read ] BatString.Cap.t -> int -> char -> int option
val rindex_from : [> `Read ] BatString.Cap.t -> int -> char -> int option
val find :
[> `Read ] BatString.Cap.t -> [> `Read ] BatString.Cap.t -> int option
val find_from :
[> `Read ] BatString.Cap.t ->
int -> [> `Read ] BatString.Cap.t -> int option
val rfind :
[> `Read ] BatString.Cap.t -> [> `Read ] BatString.Cap.t -> int option
val rfind_from :
[> `Read ] BatString.Cap.t ->
int -> [> `Read ] BatString.Cap.t -> int option
val split :
[> `Read ] BatString.Cap.t ->
by:[> `Read ] BatString.Cap.t ->
('a BatString.Cap.t * 'b BatString.Cap.t) option
val rsplit :
[> `Read ] BatString.Cap.t ->
by:[> `Read ] BatString.Cap.t ->
('a BatString.Cap.t * 'b BatString.Cap.t) option
end