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