sig   external length : string -> int = "%string_length"   external get : string -> int -> char = "%string_safe_get"   external set : bytes -> int -> char -> unit = "%string_safe_set"   external create : int -> bytes = "caml_create_string"   val make : int -> char -> string   val init : int -> (int -> char) -> string   val copy : string -> string   val sub : string -> int -> int -> string   val fill : bytes -> int -> int -> char -> unit   val blit : string -> int -> bytes -> int -> int -> unit   val concat : string -> string list -> string   val iter : (char -> unit) -> string -> unit   val iteri : (int -> char -> unit) -> string -> unit   val map : (char -> char) -> string -> string   val mapi : (int -> char -> char) -> string -> string   val trim : string -> string   val escaped : string -> string   val index : string -> char -> int   val rindex : string -> char -> int   val index_from : string -> int -> char -> int   val rindex_from : string -> int -> char -> int   val contains : string -> char -> bool   val contains_from : string -> int -> char -> bool   val rcontains_from : string -> int -> char -> bool   val uppercase : string -> string   val lowercase : string -> string   val capitalize : string -> string   val uncapitalize : string -> string   val uppercase_ascii : string -> string   val lowercase_ascii : string -> string   val capitalize_ascii : string -> string   val uncapitalize_ascii : string -> string   type t = string   val compare : t -> t -> int   val equal : t -> t -> bool   external unsafe_get : string -> int -> char = "%string_unsafe_get"   external unsafe_set : bytes -> int -> char -> unit = "%string_unsafe_set"   external unsafe_blit : string -> int -> bytes -> int -> int -> unit     = "caml_blit_string" [@@noalloc]   external unsafe_fill : bytes -> int -> int -> char -> unit     = "caml_fill_string" [@@noalloc]   val head : string -> char option   val is_prefix : affix:string -> string -> bool   val is_suffix : affix:string -> string -> bool   val for_all : (char -> bool) -> string -> bool   val exists : (char -> bool) -> string -> bool   val with_index_range : ?first:int -> ?last:int -> string -> string   val cut : ?rev:bool -> sep:char -> string -> (string * string) option   val cuts : ?empty:bool -> sep:char -> string -> string list   val parse_version : string -> (int * int * int * string option) option   val drop_initial_v : string -> string end