1995-08-09 08:06:35 -07:00
|
|
|
(***********************************************************************)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Objective Caml *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Copyright 1996 Institut National de Recherche en Informatique et *)
|
1999-11-17 10:59:06 -08:00
|
|
|
(* en Automatique. All rights reserved. This file is distributed *)
|
|
|
|
(* under the terms of the GNU Library General Public License. *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(***********************************************************************)
|
|
|
|
|
|
|
|
(* $Id$ *)
|
|
|
|
|
1995-08-09 06:15:01 -07:00
|
|
|
(* Module [String]: string operations *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
1995-07-10 02:48:27 -07:00
|
|
|
external length : string -> int = "%string_length"
|
1995-08-09 06:15:01 -07:00
|
|
|
(* Return the length (number of characters) of the given string. *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
1995-07-10 02:48:27 -07:00
|
|
|
external get : string -> int -> char = "%string_safe_get"
|
1995-08-09 06:15:01 -07:00
|
|
|
(* [String.get s n] returns character number [n] in string [s].
|
|
|
|
The first character is character number 0.
|
|
|
|
The last character is character number [String.length s - 1].
|
1998-11-05 00:04:09 -08:00
|
|
|
Raise [Invalid_argument] if [n] is outside the range
|
1995-08-09 06:15:01 -07:00
|
|
|
0 to [(String.length s - 1)].
|
|
|
|
You can also write [s.[n]] instead of [String.get s n]. *)
|
1995-07-10 02:48:27 -07:00
|
|
|
external set : string -> int -> char -> unit = "%string_safe_set"
|
1995-08-09 06:15:01 -07:00
|
|
|
(* [String.set s n c] modifies string [s] in place,
|
|
|
|
replacing the character number [n] by [c].
|
1998-11-05 00:04:09 -08:00
|
|
|
Raise [Invalid_argument] if [n] is outside the range
|
1995-08-09 06:15:01 -07:00
|
|
|
0 to [(String.length s - 1)].
|
|
|
|
You can also write [s.[n] <- c] instead of [String.set s n c]. *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
2000-04-02 18:57:52 -07:00
|
|
|
external create : int -> string = "create_string"
|
1995-08-09 06:15:01 -07:00
|
|
|
(* [String.create n] returns a fresh string of length [n].
|
1999-10-02 05:09:43 -07:00
|
|
|
The string initially contains arbitrary characters.
|
|
|
|
Raise [Invalid_argument] if [n <= 0] or [n > Sys.max_string_length].
|
|
|
|
*)
|
2000-04-02 18:57:52 -07:00
|
|
|
val make : int -> char -> string
|
1995-08-09 06:15:01 -07:00
|
|
|
(* [String.make n c] returns a fresh string of length [n],
|
1999-10-02 05:09:43 -07:00
|
|
|
filled with the character [c].
|
|
|
|
Raise [Invalid_argument] if [n <= 0] or [n > Sys.max_string_length].
|
|
|
|
*)
|
1995-05-04 03:15:53 -07:00
|
|
|
val copy : string -> string
|
1995-08-09 06:15:01 -07:00
|
|
|
(* Return a copy of the given string. *)
|
1999-11-30 08:07:38 -08:00
|
|
|
val sub : string -> pos:int -> len:int -> string
|
1995-08-09 06:15:01 -07:00
|
|
|
(* [String.sub s start len] returns a fresh string of length [len],
|
|
|
|
containing the characters number [start] to [start + len - 1]
|
|
|
|
of string [s].
|
|
|
|
Raise [Invalid_argument] if [start] and [len] do not
|
|
|
|
designate a valid substring of [s]; that is, if [start < 0],
|
|
|
|
or [len < 0], or [start + len > String.length s]. *)
|
1999-11-30 08:07:38 -08:00
|
|
|
val fill : string -> pos:int -> len:int -> char -> unit
|
1995-12-06 07:46:34 -08:00
|
|
|
(* [String.fill s start len c] modifies string [s] in place,
|
1995-08-09 06:15:01 -07:00
|
|
|
replacing the characters number [start] to [start + len - 1]
|
|
|
|
by [c].
|
|
|
|
Raise [Invalid_argument] if [start] and [len] do not
|
|
|
|
designate a valid substring of [s]. *)
|
1999-12-07 07:01:27 -08:00
|
|
|
val blit : src:string -> src_pos:int ->
|
|
|
|
dst:string -> dst_pos:int -> len:int -> unit
|
1997-09-11 08:10:23 -07:00
|
|
|
(* [String.blit src srcoff dst dstoff len] copies [len] characters
|
|
|
|
from string [src], starting at character number [srcoff], to
|
|
|
|
string [dst], starting at character number [dstoff]. It works
|
|
|
|
correctly even if [src] and [dst] are the same string,
|
1995-08-09 06:15:01 -07:00
|
|
|
and the source and destination chunks overlap.
|
1997-09-11 08:10:23 -07:00
|
|
|
Raise [Invalid_argument] if [srcoff] and [len] do not
|
|
|
|
designate a valid substring of [src], or if [dstoff] and [len]
|
|
|
|
do not designate a valid substring of [dst]. *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
1999-11-30 08:07:38 -08:00
|
|
|
val concat : sep:string -> string list -> string
|
1995-12-06 07:46:34 -08:00
|
|
|
(* [String.concat sep sl] catenates the list of strings [sl],
|
|
|
|
inserting the separator string [sep] between each. *)
|
1995-05-05 03:05:18 -07:00
|
|
|
|
1995-05-04 03:15:53 -07:00
|
|
|
val escaped: string -> string
|
1995-08-09 06:15:01 -07:00
|
|
|
(* Return a copy of the argument, with special characters represented
|
|
|
|
by escape sequences, following the lexical conventions of
|
1997-06-20 05:48:44 -07:00
|
|
|
Objective Caml. *)
|
1995-08-09 06:15:01 -07:00
|
|
|
|
2000-04-02 18:57:52 -07:00
|
|
|
val index: string -> char -> int
|
1998-04-27 02:55:50 -07:00
|
|
|
(* [String.index s c] returns the position of the leftmost
|
|
|
|
occurrence of character [c] in string [s].
|
|
|
|
Raise [Not_found] if [c] does not occur in [s]. *)
|
2000-04-02 18:57:52 -07:00
|
|
|
val rindex: string -> char -> int
|
1998-04-27 02:55:50 -07:00
|
|
|
(* [String.rindex s c] returns the position of the rightmost
|
|
|
|
occurrence of character [c] in string [s].
|
|
|
|
Raise [Not_found] if [c] does not occur in [s]. *)
|
2000-04-02 18:57:52 -07:00
|
|
|
val index_from: string -> int -> char -> int
|
|
|
|
val rindex_from: string -> int -> char -> int
|
1998-04-27 02:55:50 -07:00
|
|
|
(* Same as [String.index] and [String.rindex], but start
|
|
|
|
searching at the character position given as second argument.
|
|
|
|
[String.index s c] is equivalent to [String.index_from s 0 c],
|
|
|
|
and [String.rindex s c] to
|
|
|
|
[String.rindex_from s (String.length s - 1) c]. *)
|
1997-10-24 08:54:07 -07:00
|
|
|
|
2000-04-02 18:57:52 -07:00
|
|
|
val contains : string -> char -> bool
|
1998-11-12 06:53:46 -08:00
|
|
|
(* [String.contains s c] tests if character [c]
|
|
|
|
appears in the string [s]. *)
|
2000-04-02 18:57:52 -07:00
|
|
|
val contains_from : string -> int -> char -> bool
|
1998-11-12 06:53:46 -08:00
|
|
|
(* [String.contains_from s start c] tests if character [c]
|
|
|
|
appears in the substring of [s] starting from [start] to the end
|
|
|
|
of [s].
|
|
|
|
Raise [Invalid_argument] if [start] is not a valid index of [s]. *)
|
2000-04-02 18:57:52 -07:00
|
|
|
val rcontains_from : string -> int -> char -> bool
|
1998-11-12 06:53:46 -08:00
|
|
|
(* [String.rcontains_from s stop c] tests if character [c]
|
|
|
|
appears in the substring of [s] starting from the beginning
|
|
|
|
of [s] to index [stop].
|
|
|
|
Raise [Invalid_argument] if [stop] is not a valid index of [s]. *)
|
|
|
|
|
1996-10-31 08:03:04 -08:00
|
|
|
val uppercase: string -> string
|
|
|
|
(* Return a copy of the argument, with all lowercase letters
|
1997-06-20 05:48:44 -07:00
|
|
|
translated to uppercase, including accented letters of the ISO
|
|
|
|
Latin-1 (8859-1) character set. *)
|
1996-10-31 08:03:04 -08:00
|
|
|
val lowercase: string -> string
|
|
|
|
(* Return a copy of the argument, with all uppercase letters
|
1997-06-20 05:48:44 -07:00
|
|
|
translated to lowercase, including accented letters of the ISO
|
|
|
|
Latin-1 (8859-1) character set. *)
|
1996-10-31 08:03:04 -08:00
|
|
|
val capitalize: string -> string
|
|
|
|
(* Return a copy of the argument, with the first letter
|
|
|
|
set to uppercase. *)
|
|
|
|
val uncapitalize: string -> string
|
|
|
|
(* Return a copy of the argument, with the first letter
|
|
|
|
set to lowercase. *)
|
|
|
|
|
1995-08-09 06:15:01 -07:00
|
|
|
(*--*)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
1995-06-15 01:10:01 -07:00
|
|
|
external unsafe_get : string -> int -> char = "%string_unsafe_get"
|
|
|
|
external unsafe_set : string -> int -> char -> unit = "%string_unsafe_set"
|
1999-11-30 08:07:38 -08:00
|
|
|
external unsafe_blit :
|
2000-01-07 08:47:25 -08:00
|
|
|
src:string -> src_pos:int ->
|
1999-12-07 07:01:27 -08:00
|
|
|
dst:string -> dst_pos:int -> len:int -> unit
|
1999-11-30 08:07:38 -08:00
|
|
|
= "blit_string" "noalloc"
|
|
|
|
external unsafe_fill : string -> pos:int -> len:int -> char -> unit
|
|
|
|
= "fill_string" "noalloc"
|