Module Base.String
An extension of the standard StringLabels. If you open Base, you'll get these extensions in the String module.
include Sexpable.S with type t := t
- val t_of_sexp : Sexplib0.Sexp.t -> t
- val sexp_of_t : t -> Sexplib0.Sexp.t
include Container.S0 with type t := t with type elt = char
- val length : t -> int
- val is_empty : t -> bool
- val iter : t -> f:(elt -> unit) -> unit
- itermust allow exceptions raised in- fto escape, terminating the iteration cleanly. The same holds for all functions below taking an- f.
- val fold : t -> init:'accum -> f:('accum -> elt -> 'accum) -> 'accum
- fold t ~init ~freturns- f (... f (f (f init e1) e2) e3 ...) en, where- e1..enare the elements of- t.
- val fold_result : t -> init:'accum -> f:('accum -> elt -> ('accum, 'e) Result.t) -> ('accum, 'e) Result.t
- fold_result t ~init ~fis a short-circuiting version of- foldthat runs in the- Resultmonad. If- freturns an- Error _, that value is returned without any additional invocations of- f.
- val fold_until : t -> init:'accum -> f:('accum -> elt -> ('accum, 'final) Base__.Container_intf.Continue_or_stop.t) -> finish:('accum -> 'final) -> 'final
- fold_until t ~init ~f ~finishis a short-circuiting version of- fold. If- freturns- Stop _the computation ceases and results in that value. If- freturns- Continue _, the fold will proceed. If- fnever returns- Stop _, the final result is computed by- finish.- Example: - type maybe_negative = | Found_negative of int | All_nonnegative of { sum : int } (** [first_neg_or_sum list] returns the first negative number in [list], if any, otherwise returns the sum of the list. *) let first_neg_or_sum = List.fold_until ~init:0 ~f:(fun sum x -> if x < 0 then Stop (Found_negative x) else Continue (sum + x)) ~finish:(fun sum -> All_nonnegative { sum }) ;; let x = first_neg_or_sum [1; 2; 3; 4; 5] val x : maybe_negative = All_nonnegative {sum = 15} let y = first_neg_or_sum [1; 2; -3; 4; 5] val y : maybe_negative = Found_negative -3
- val exists : t -> f:(elt -> bool) -> bool
- Returns - trueif and only if there exists an element for which the provided function evaluates to- true. This is a short-circuiting operation.
- val for_all : t -> f:(elt -> bool) -> bool
- Returns - trueif and only if the provided function evaluates to- truefor all elements. This is a short-circuiting operation.
- val count : t -> f:(elt -> bool) -> int
- Returns the number of elements for which the provided function evaluates to true. 
- val sum : (module Base__.Container_intf.Summable with type t = 'sum) -> t -> f:(elt -> 'sum) -> 'sum
- Returns the sum of - f ifor all- iin the container.
- val find : t -> f:(elt -> bool) -> elt option
- Returns as an - optionthe first element for which- fevaluates to true.
- val find_map : t -> f:(elt -> 'a option) -> 'a option
- Returns the first evaluation of - fthat returns- Some, and returns- Noneif there is no such element.
- val to_list : t -> elt list
- val to_array : t -> elt array
- val min_elt : t -> compare:(elt -> elt -> int) -> elt option
- Returns a min (resp. max) element from the collection using the provided - comparefunction. In case of a tie, the first element encountered while traversing the collection is returned. The implementation uses- foldso it has the same complexity as- fold. Returns- Noneiff the collection is empty.
include Identifiable.S with type t := t
- val hash_fold_t : Hash.state -> t -> Hash.state
- val hash : t -> Hash.hash_value
include Sexpable.S with type t := t
- val t_of_sexp : Sexplib0.Sexp.t -> t
- val sexp_of_t : t -> Sexplib0.Sexp.t
include Comparable.S with type t := t
include Base__.Comparable_intf.Polymorphic_compare
- val ascending : t -> t -> int
- ascendingis identical to- compare.- descending x y = ascending y x. These are intended to be mnemonic when used like- List.sort ~compare:ascendingand- List.sort ~cmp:descending, since they cause the list to be sorted in ascending or descending order, respectively.
- val descending : t -> t -> int
- val between : t -> low:t -> high:t -> bool
- between t ~low ~highmeans- low <= t <= high
- val clamp_exn : t -> min:t -> max:t -> t
- clamp_exn t ~min ~maxreturns- t', the closest value to- tsuch that- between t' ~low:min ~high:maxis true.- Raises if - not (min <= max).
- val clamp : t -> min:t -> max:t -> t Or_error.t
include Comparator.S with type t := t
- val comparator : (t, comparator_witness) Comparator.comparator
include Base__.Comparable_intf.Validate with type t := t
- val validate_lbound : min:t Maybe_bound.t -> t Validate.check
- val validate_ubound : max:t Maybe_bound.t -> t Validate.check
- val validate_bound : min:t Maybe_bound.t -> max:t Maybe_bound.t -> t Validate.check
- val length : t -> int
- val get : t -> int -> char
- val unsafe_get : string -> int -> char
- unsafe_get t iis like- get t ibut does not perform bounds checking. The caller must ensure that it is a memory-safe operation.
- val make : int -> char -> t
- val copy : t -> t
- Assuming you haven't passed -unsafe-string to the compiler, strings are immutable, so there'd be no motivation to make a copy. 
- val init : int -> f:(int -> char) -> t
- val (^) : t -> t -> t
- String append. Also available unqualified, but re-exported here for documentation purposes. - Note that - a ^ bmust copy both- aand- binto a newly-allocated result string, so- a ^ b ^ c ^ ... ^ zis quadratic in the number of strings.- String.concatdoes not have this problem -- it allocates the result buffer only once.
- val concat : ?sep:t -> t list -> t
- Concatenates all strings in the list using separator - sep(with a default separator- "").
- val escaped : t -> t
- Special characters are represented by escape sequences, following the lexical conventions of OCaml. 
- val contains : ?pos:int -> ?len:int -> t -> char -> bool
- val uppercase : t -> t
- Operates on the whole string using the US-ASCII character set, e.g. - uppercase "foo" = "FOO".
- val lowercase : t -> t
- val capitalize : t -> t
- Operates on just the first character using the US-ASCII character set, e.g. - capitalize "foo" = "Foo".
- module Caseless : sig ... end
- Caselesscompares and hashes strings ignoring case, so that for example- Caseless.equal "OCaml" "ocaml"and- Caseless.("apple" < "Banana")are- true.
- val index : t -> char -> int option
- index_exnand- index_from_exnraise- Caml.Not_foundor- Not_found_swhen- charcannot be found in- s.
- val index_exn : t -> char -> int
- val index_from : t -> int -> char -> int option
- val index_from_exn : t -> int -> char -> int
- val rindex : t -> char -> int option
- rindex_exnand- rindex_from_exnraise- Caml.Not_foundor- Not_found_swhen- charcannot be found in- s.
- val rindex_exn : t -> char -> int
- val rindex_from : t -> int -> char -> int option
- val rindex_from_exn : t -> int -> char -> int
- module Search_pattern : sig ... end
- Substring search and replace functions. They use the Knuth-Morris-Pratt algorithm (KMP) under the hood. 
- val substr_index : ?pos:int -> t -> pattern:t -> int option
- Substring search and replace convenience functions. They call - Search_pattern.createand then forget the preprocessed pattern when the search is complete.- pos < 0or- pos >= length tresult in no match (hence- substr_indexreturns- Noneand- substr_index_exnraises).- may_overlapindicates whether to report overlapping matches, see- Search_pattern.index_all.
- val substr_index_exn : ?pos:int -> t -> pattern:t -> int
- val substr_index_all : t -> may_overlap:bool -> pattern:t -> int list
- val substr_replace_first : ?pos:int -> t -> pattern:t -> with_:t -> t
- val substr_replace_all : t -> pattern:t -> with_:t -> t
- As with - Search_pattern.replace_all, the result may still contain- pattern.
- val is_substring_at : t -> pos:int -> substring:t -> bool
- is_substring_at "foo bar baz" ~pos:4 ~substring:"bar"is true.
- val to_list_rev : t -> char list
- Returns the reversed list of characters contained in a list. 
- val lsplit2_exn : t -> on:char -> t * t
- If the string - scontains the character- on, then- lsplit2_exn s ~onreturns a pair containing- ssplit around the first appearance of- on(from the left). Raises- Caml.Not_foundor- Not_found_swhen- oncannot be found in- s.
- val rsplit2_exn : t -> on:char -> t * t
- If the string - scontains the character- on, then- rsplit2_exn s ~onreturns a pair containing- ssplit around the first appearance of- on(from the right). Raises- Caml.Not_foundor- Not_found_swhen- oncannot be found in- s.
- val lsplit2 : t -> on:char -> (t * t) option
- lsplit2 s ~onoptionally returns- ssplit into two strings around the first appearance of- onfrom the left.
- val rsplit2 : t -> on:char -> (t * t) option
- rsplit2 s ~onoptionally returns- ssplit into two strings around the first appearance of- onfrom the right.
- val split : t -> on:char -> t list
- split s ~onreturns a list of substrings of- sthat are separated by- on. Consecutive- oncharacters will cause multiple empty strings in the result. Splitting the empty string returns a list of the empty string, not the empty list.
- val split_on_chars : t -> on:char list -> t list
- split_on_chars s ~onreturns a list of all substrings of- sthat are separated by one of the chars from- on.- onare not grouped. So a grouping of- onin the source string will produce multiple empty string splits in the result.
- val split_lines : t -> t list
- split_lines treturns the list of lines that comprise- t. The lines do not include the trailing- "\n"or- "\r\n".
- val lfindi : ?pos:int -> t -> f:(int -> char -> bool) -> int option
- lfindi ?pos t ~freturns the smallest- i >= possuch that- f i t.[i], if there is such an- i. By default,- pos = 0.
- val rfindi : ?pos:int -> t -> f:(int -> char -> bool) -> int option
- rfindi ?pos t ~freturns the largest- i <= possuch that- f i t.[i], if there is such an- i. By default- pos = length t - 1.
- val lstrip : ?drop:(char -> bool) -> t -> t
- lstrip ?drop sreturns a string with consecutive chars satisfying- drop(by default white space, e.g. tabs, spaces, newlines, and carriage returns) stripped from the beginning of- s.
- val rstrip : ?drop:(char -> bool) -> t -> t
- rstrip ?drop sreturns a string with consecutive chars satisfying- drop(by default white space, e.g. tabs, spaces, newlines, and carriage returns) stripped from the end of- s.
- val strip : ?drop:(char -> bool) -> t -> t
- strip ?drop sreturns a string with consecutive chars satisfying- drop(by default white space, e.g. tabs, spaces, newlines, and carriage returns) stripped from the beginning and end of- s.
- val map : t -> f:(char -> char) -> t
- val mapi : t -> f:(int -> char -> char) -> t
- Like - map, but passes each character's index to- falong with the char.
- val foldi : t -> init:'a -> f:(int -> 'a -> char -> 'a) -> 'a
- foldiworks similarly to- fold, but also passes the index of each character to- f.
- val concat_map : ?sep:t -> t -> f:(char -> t) -> t
- Like - map, but allows the replacement of a single character with zero or two or more characters.
- val filter : t -> f:(char -> bool) -> t
- filter s ~f:predicatediscards characters not satisfying- predicate.
- val tr : target:char -> replacement:char -> t -> t
- tr ~target ~replacement sreplaces every instance of- targetin- swith- replacement.
- val tr_multi : target:t -> replacement:t -> (t -> t) Staged.t
- tr_multi ~target ~replacementreturns a function that replaces every instance of a character in- targetwith the corresponding character in- replacement.- If - replacementis shorter than- target, it is lengthened by repeating its last character. Empty- replacementis illegal unless- targetalso is.- If - targetcontains multiple copies of the same character, the last corresponding- replacementcharacter is used. Note that character ranges are not supported, so- ~target:"a-z"means the literal characters- 'a',- '-', and- 'z'.
- val chop_suffix_exn : t -> suffix:t -> t
- chop_suffix_exn s ~suffixreturns- swithout the trailing- suffix, raising- Invalid_argumentif- suffixis not a suffix of- s.
- val chop_prefix_exn : t -> prefix:t -> t
- chop_prefix_exn s ~prefixreturns- swithout the leading- prefix, raising- Invalid_argumentif- prefixis not a prefix of- s.
- val chop_suffix : t -> suffix:t -> t option
- val chop_prefix : t -> prefix:t -> t option
- val chop_suffix_if_exists : t -> suffix:t -> t
- chop_suffix_if_exists s ~suffixreturns- swithout the trailing- suffix, or just- sif- suffixisn't a suffix of- s.- Equivalent to - chop_suffix s ~suffix |> Option.value ~default:s, but avoids allocating the intermediate option.
- val chop_prefix_if_exists : t -> prefix:t -> t
- chop_prefix_if_exists s ~prefixreturns- swithout the leading- prefix, or just- sif- prefixisn't a prefix of- s.- Equivalent to - chop_prefix s ~prefix |> Option.value ~default:s, but avoids allocating the intermediate option.
- val suffix : t -> int -> t
- suffix s nreturns the longest suffix of- sof length less than or equal to- n.
- val prefix : t -> int -> t
- prefix s nreturns the longest prefix of- sof length less than or equal to- n.
- val drop_suffix : t -> int -> t
- drop_suffix s ndrops the longest suffix of- sof length less than or equal to- n.
- val drop_prefix : t -> int -> t
- drop_prefix s ndrops the longest prefix of- sof length less than or equal to- n.
- val concat_array : ?sep:t -> t array -> t
- concat_array sep arlike- String.concat, but operates on arrays.
- val hash : t -> int
- Slightly faster hash function on strings. 
- module Escaping : sig ... end
- Operations for escaping and unescaping strings, with parameterized escape and escapeworthy characters. Escaping/unescaping using this module is more efficient than using Pcre. Benchmark code can be found in core/benchmarks/string_escaping.ml.