sig   type 'a t = '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 map : (char -> char) -> [> `Read ] t -> 'a t   val mapi : (int -> char -> char) -> [> `Read ] t -> 'a t   val fold_left : ('-> char -> 'a) -> '-> [> `Read ] t -> 'a   val fold_lefti : ('-> int -> char -> 'a) -> '-> [> `Read ] t -> 'a   val fold_right : (char -> '-> 'a) -> [> `Read ] t -> '-> 'a   val fold_righti : (int -> char -> '-> 'a) -> [> `Read ] t -> '-> '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 contains : [> `Read ] t -> char -> bool   val contains_from : [> `Read ] t -> int -> char -> bool   val rcontains_from : [> `Read ] t -> int -> char -> bool   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 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 : 'BatInnerIO.output -> [> `Read ] t -> unit   val println : 'BatInnerIO.output -> [> `Read ] t -> unit   val print_quoted : '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 = BatString.Cap.Exceptionless   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 ->     ('BatString.Cap.t * 'BatString.Cap.t) option   val rsplit :     [> `Read ] BatString.Cap.t ->     by:[> `Read ] BatString.Cap.t ->     ('BatString.Cap.t * 'BatString.Cap.t) option end