This file is indexed.

/usr/lib/ocaml/netstring-pcre/netstring_pcre.mli is in libocamlnet-ocaml-dev 3.7.3-3build2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
(* $Id: netstring_pcre.mlip 1791 2012-07-19 23:01:25Z gerd $ *)
(** Wrapper for regexps with PCRE syntax
 *
 * This module is a version of [Str] with a thread-safe interface,
 * implemented using Pcre. 
 *
 * This modules processes PCRE-style regular expressions. If you like
 * to write [Str]-like regexps, you can also use {!Netstring_str} with
 * almost the same signature.
 *
 * {b The functions in this module are unavailable if Ocamlnet is built
 * with [Str] as implementation of regular expressions! They will always
 * raise [Invalid_argument]!}
 *)
(** Supported regexp syntax: See pcrepattern(3). *)
type regexp = Pcre.regexp

(** The type of regular expressions; now based on [Pcre] *)
type split_result =
  Pcre.split_result =
    | Text of string | Delim of string | Group of int * string | NoGroup

(** Here we keep compatiblity with [Pcre] *)
type result

(** The type of matching results *)
val regexp : string -> regexp
  
(** Parses a regexp *)
val regexp_case_fold : string -> regexp
  
(** Parses a case-insensitive regexp *)
val quote : string -> string
  
(** Quotes a string such that it can be included in a regexp *)
val regexp_string : string -> regexp
  
(** Returns a regexp that matches exactly the string *)
val regexp_string_case_fold : string -> regexp
  
(** Returns a case-insensitive regexp that matches exactly the string *)
val string_match : regexp -> string -> int -> result option
  
(** Matches the string at the position with the regexp. Returns
   * [None] if no match is found. Returns [Some r] on success,
   * and [r] describes the match.
   *)
val search_forward : regexp -> string -> int -> (int * result)
  
(** Searches a match of the string with the regexp, starting at
   * the position and in forward direction.
   * Raises [Not_found] if no match could be found.
   * Returns [(p,r)] when a match at position [p] is found,
   * described by [r].
   *)
val search_backward : regexp -> string -> int -> (int * result)
  
(** Searches a match of the string with the regexp, starting at
   * the position and in backward direction.
   * Raises [Not_found] if no match could be found.
   * Returns [(p,r)] when a match at position [p] is found,
   * described by [r].
   *)
(*
  string_partial_match: not available
*)
(* The ~groups option is ignored *)
val matched_string : result -> string -> string
  
(** Extracts the matched part from the string. The string argument
   * must be the same string passed to [string_match] or the search
   * functions, and the result argument must be the corresponding
   * result.
   *)
val match_beginning : result -> int
  
(** Returns the position where the matched part begins *)
val match_end : result -> int
  
(** Returns the position where the matched part ends *)
val matched_group : result -> int -> string -> string
  
(** Extracts the substring the nth group matches from the whole
   * string. The string argument
   * must be the same string passed to [string_match] or the search
   * functions, and the result argument must be the corresponding
   * result.
   *)
val group_beginning : result -> int -> int
  
(** Returns the position where the substring matching the nth
   * group begins 
   *)
val group_end : result -> int -> int
  
(** Returns the position where the substring matching the nth
   * group ends 
   *)
val global_replace : regexp -> string -> string -> string
  
(** [global_replace re templ s]: Replaces all matchings of [re] in
   * [s] by [templ].
   *
   * In [templ] one can refer to matched groups by the backslash notation:
   * [\1] refers to the first group, [\2] to the second etc.
   * [\0] is the whole match. [\\ ] is the backslash character.
   *)
val replace_first : regexp -> string -> string -> string
  
(** [replace_first re templ s]: Replaces the first match of [re] in
   * [s] by [templ].
   *
   * In [templ] one can refer to matched groups by the backslash notation:
   * [\1] refers to the first group, [\2] to the second etc.
   * [\0] is the whole match. [\\ ] is the backslash character.
   *)
val global_substitute :
  regexp -> (result -> string -> string) -> string -> string
  
(** [global_substitute re subst s]: Applies the substitution function
   * [subst] to all matchings of [re] in [s], and returns the 
   * transformed string. [subst] is called with the current [result]
   * of the match and the whole string [s].
   *)
val substitute_first :
  regexp -> (result -> string -> string) -> string -> string
  
(** [substitute_first re subst s]: Applies the substitution function
   * [subst] to the first matching of [re] in [s], and returns the 
   * transformed string. [subst] is called with the current [result]
   * of the match and the whole string [s].
   *)
(* replace_matched: not available *)
val split : regexp -> string -> string list
  
(** Splits the string according to the regexp in substrings.
   * Occurrences of the delimiter at the beginning and the end
   * are ignored.
   *)
val bounded_split : regexp -> string -> int -> string list
  
(** Splits into at most [n] substrings, based on [split] *)
val split_delim : regexp -> string -> string list
  
(** Same as [split], but occurrences of the delimiter at the beginning 
   * and the end are returned as empty strings
   *)
val bounded_split_delim : regexp -> string -> int -> string list
  
(** Splits into at most [n] substrings, based on [split_delim] *)
val full_split : regexp -> string -> split_result list
  
(** Like [split_delim], but returns the delimiters in the result *)
val bounded_full_split : regexp -> string -> int -> split_result list
  
(** Splits into at most [n] substrings, based on [full_split] *)
val string_before : string -> int -> string
  
(** The first [n] characters of a string *)
val string_after : string -> int -> string
  
(** The last [n] characters of a string *)
val first_chars : string -> int -> string
  
(** Same as [string_before] *)
val last_chars : string -> int -> string