/usr/lib/ocaml/batteries/batInnerIO.mli is in libbatteries-ocaml-dev 2.2-1.
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 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 | (*
* BatInnerIO - Abstract input/output (inner module)
* Copyright (C) 2003 Nicolas Cannasse
* 2008 David Teller
* 2008 Philippe Strauss
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version,
* with the special exception on linking described in file LICENSE.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*)
(**
Core of the BatIO module.
This module contains the core definitions of {!BatIO}, so as to avoid circular
dependencies between modules which only need simple functions of {!BatIO} and
that module itself.
Don't use this module, use {!BatIO}.
@author Nicolas Cannasse
@author David Teller
@author Philippe Strauss
@author Edgar Friendly
*)
type input
type 'a output
exception No_more_input
(** This exception is raised when reading on an input with the [read] or
[nread] functions while there is no available token to read. *)
exception Input_closed
(** This exception is raised when reading on a closed input. *)
exception Output_closed
(** This exception is raised when reading on a closed output. *)
val read : input -> char
(** Read a single char from an input or raise [No_more_input] if
no input available. *)
val read_all : input -> string
(** read all the contents of the input until [No_more_input] is raised. *)
val pipe : unit -> input * unit output
(** Create a pipe between an input and an ouput. Data written from
the output can be read from the input. *)
val nread : input -> int -> string
(** [nread i n] reads a string of size up to [n] from an input.
The function will raise [No_more_input] if no input is available.
It will raise [Invalid_argument] if [n] < 0. *)
val really_nread : input -> int -> string
(** [really_nread i n] reads a string of exactly [n] characters
from the input. @raise No_more_input if at least [n] characters are
not available. @raise Invalid_argument if [n] < 0. *)
val input : input -> string -> int -> int -> int
(** [input i s p l] reads up to [l] characters from the given input, storing
them in string [s], starting at character number [p]. It returns the actual
number of characters read or raise [No_more_input] if no character can be
read. It will raise [Invalid_argument] if [p] and [l] do not designate a
valid substring of [s]. *)
val really_input : input -> string -> int -> int -> int
(** [really_input i s p l] reads exactly [l] characters from the given input,
storing them in the string [s], starting at position [p]. For consistency with
{!BatIO.input} it returns [l]. @raise No_more_input if at [l] characters are
not available. @raise Invalid_argument if [p] and [l] do not designate a
valid substring of [s]. *)
val close_in : input -> unit
(** Close the input. It can no longer be read from. *)
(*val auto_close_in : input -> input
(** Create a new channel which will close automatically once there is nothing
left to read.*)*)
val write : 'a output -> char -> unit
(** Write a single char to an output. *)
val nwrite : 'a output -> string -> unit
(** Write a string to an output. *)
val output : 'a output -> string -> int -> int -> int
(** [output o s p l] writes up to [l] characters from string [s], starting at
offset [p]. It returns the number of characters written. It will raise
[Invalid_argument] if [p] and [l] do not designate a valid substring of [s]. *)
val really_output : 'a output -> string -> int -> int -> int
(** [really_output o s p l] writes exactly [l] characters from string [s] onto
the the output, starting with the character at offset [p]. For consistency with
{!BatIO.output} it returns [l]. @raise Invalid_argument if [p] and [l] do not
designate a valid substring of [s]. *)
val flush : 'a output -> unit
(** Flush an output. *)
val flush_all : unit -> unit
(** Flush all outputs. *)
val close_out : 'a output -> 'a
(** Close the output and return its accumulator data.
It can no longer be written. *)
val close_all : unit -> unit
(** Close all outputs.
Ignore errors.*)
val input_string : string -> input
(** Create an input that will read from a string. *)
val output_string : unit -> string output
(** Create an output that will write into a string in an efficient way.
When closed, the output returns all the data written into it. *)
val on_close_out : 'a output -> ('a output -> unit) -> unit
(**
Register a function to be triggered just before an output is closed.
*)
val create_in :
read:(unit -> char) ->
input:(string -> int -> int -> int) ->
close:(unit -> unit) -> input
(** Fully create an input by giving all the needed functions.
{b Note} Do {e not} use this function for creating an input
which reads from one or more underlying inputs. Rather, use
{!wrap_in}.
*)
val inherit_in:
?read:(unit -> char) ->
?input:(string -> int -> int -> int) ->
?close:(unit -> unit) ->
input -> input
(**
Simplified and optimized version of {!wrap_in} whenever only
one input appears as dependency.
*)
val wrap_in :
read:(unit -> char) ->
input:(string -> int -> int -> int) ->
close:(unit -> unit) ->
underlying:(input list) ->
input
(** Fully create an input reading from other inputs by giving all the needed functions.
This function is a more general version of {!create_in}
which also handles dependency management between inputs.
*)
val create_out :
write:(char -> unit) ->
output:(string -> int -> int -> int) ->
flush:(unit -> unit) ->
close:(unit -> 'a) ->
'a output
(**
Fully create an output by giving all the needed functions.
@param write Write one character to the output (see {!write}).
@param output Write a (sub)string to the output (see {!output}).
@param flush Flush any buffers of this output (see {!flush}).
@param close Close this output. The output will be automatically
flushed.
{b Note} Do {e not} use this function for creating an output which
writes to one or more underlying outputs. Rather, use {!wrap_out}.
*)
val inherit_out:
?write:(char -> unit) ->
?output:(string -> int -> int -> int) ->
?flush:(unit -> unit) ->
?close:(unit -> unit) ->
_ output -> unit output
(**
Simplified and optimized version of {!wrap_out} whenever only
one output appears as dependency.
*)
val wrap_out :
write:(char -> unit) ->
output:(string -> int -> int -> int) ->
flush:(unit -> unit) ->
close:(unit -> 'a) ->
underlying:('b output list) ->
'a output
(**
Fully create an output that writes to one or more underlying outputs.
This function is a more general version of {!create_out},
which also handles dependency management between outputs.
To illustrate the need for dependency management, let us consider
the following values:
- an output [out]
- a function [f : _ output -> _ output], using {!create_out} to
create a new output for writing some data to an underyling
output (for instance, a function comparale to {!tab_out} or a
function performing transparent compression or transparent
traduction between encodings)
With these values, let us consider the following scenario
- a new output [f out] is created
- some data is written to [f out] but not flushed
- output [out] is closed, perhaps manually or as a consequence
of garbage-collection, or because the program has ended
- data written to [f out] is flushed.
In this case, data reaches [out] only after [out] has been closed,
which violates the protocol. Despite appearances, it is quite easy
to reach such situation, especially in short programs.
The solution is to use [wrap_out] rather than [create_out] in [f].
Specifying that [f out] writes on [out] will then let the run-time
flush and close [f out] when [out] is closed for any reason, which
in turn avoids the issue.
@param write Write one character to the output (see {!write}).
@param output Write a (sub)string to the output (see {!output}).
@param flush Flush any buffers of this output (see {!flush}).
@param close Close this output. The output will be automatically
flushed.
@param underlying The list of outputs to which the new output will
write.
{b Note} Function [close] should {e not} close [underlying]
yourself. This is a common mistake which may cause sockets or
standard output to be closed while they are still being used by
another part of the program.
*)
val default_buffer_size : int
(**The default size of buffers.*)
(** {6 Binary files API}
Here is some API useful for working with binary files, in particular
binary files generated by C applications. By default, encoding of
multibyte integers is low-endian. The BigEndian module provide multibyte
operations with other encoding.
*)
exception Overflow of string
(** Exception raised when a read or write operation cannot be completed. *)
val read_byte : input -> int
(** Read an unsigned 8-bit integer. *)
val read_signed_byte : input -> int
(** Read an signed 8-bit integer. *)
val read_ui16 : input -> int
(** Read an unsigned 16-bit word. *)
val read_i16 : input -> int
(** Read a signed 16-bit word. *)
val read_i32 : input -> int
(** Read a signed 32-bit integer. @raise Overflow if the
read integer cannot be represented as an OCaml 31-bit integer. *)
val read_real_i32 : input -> int32
(** Read a signed 32-bit integer as an OCaml int32. *)
val read_i64 : input -> int64
(** Read a signed 64-bit integer as an OCaml int64. *)
val read_float : input -> float
(** Read an IEEE single precision floating point value. *)
val read_double : input -> float
(** Read an IEEE double precision floating point value. *)
val read_string : input -> string
(** Read a null-terminated string. *)
val read_line : input -> string
(** Read a LF or CRLF terminated string. *)
val write_byte : 'a output -> int -> unit
(** Write an unsigned 8-bit byte. *)
val write_ui16 : 'a output -> int -> unit
(** Write an unsigned 16-bit word. *)
val write_i16 : 'a output -> int -> unit
(** Write a signed 16-bit word. *)
val write_i32 : 'a output -> int -> unit
(** Write a signed 32-bit integer. *)
val write_real_i32 : 'a output -> int32 -> unit
(** Write an OCaml int32. *)
val write_i64 : 'a output -> int64 -> unit
(** Write an OCaml int64. *)
val write_double : 'a output -> float -> unit
(** Write an IEEE double precision floating point value. *)
val write_float : 'a output -> float -> unit
(** Write an IEEE single precision floating point value. *)
val write_string : 'a output -> string -> unit
(** Write a string and append an null character. *)
val write_line : 'a output -> string -> unit
(** Write a line and append a LF (it might be converted
to CRLF on some systems depending on the underlying BatIO). *)
external cast_output : 'a output -> unit output = "%identity"
(** You can safely transform any output to an unit output in a safe way
by using this function. *)
(**
{6 For compatibility purposes}
*)
val input_channel : ?autoclose:bool -> ?cleanup:bool -> in_channel -> input
(** Create an input that will read from a channel.
@param autoclose If true or unspecified, the {!type: input}
will be automatically closed when the underlying [in_channel]
has reached its end.
@param cleanup If true, the channel
will be automatically closed when the {!type: input} is closed.
Otherwise, you will need to close the channel manually.
*)
val output_channel : ?cleanup:bool -> out_channel -> unit output
(** Create an output that will write into a channel.
@param cleanup If true, the channel
will be automatically closed when the {!type: output} is closed.
Otherwise, you will need to close the channel manually.
*)
(*
val to_input_channel : input -> in_channel
(** Create a channel that will read from an input.
{b Note} This function is very costly and is provided
essentially for debugging purposes or for reusing legacy
libraries which can't be adapted. As a general rule, if
you can avoid using this function, don't use it.*)
val to_output_channel: _ output -> out_channel
(** Create a channel that will write to an output
{b Note} This function is very costly and is provided
essentially for debugging purposes or for reusing legacy
libraries which can't be adapted. As a general rule, if
you can avoid using this function, don't use it.*)
*)
(** {6 Standard inputs/outputs} *)
val stdin : input
(** Standard input, as per Unix/Windows conventions (by default, keyboard).*)
val stdout: unit output
(** Standard output, as per Unix/Windows conventions (by default, console).
Use this output to display regular messages.*)
val stderr: unit output
(** Standard error output, as per Unix/Windows conventions.
Use this output to display warnings and error messages.
*)
val stdnull: unit output
(** An output which discards everything written to it.
Use this output to ignore messages.*)
(** {6 Comparison}
The following modules may be useful to create hashtables of inputs or outputs.
*)
module Input :
sig
type t = input
val compare : input -> input -> int
(**A total order on inputs*)
val hash : input -> int
(**A hash function for inputs*)
val equal : input -> input -> bool
end
module Output :
sig
type t = unit output
val compare : _ output -> _ output -> int
(**A total order on outputs*)
val hash : _ output -> int
(**A hash function for outputs*)
val equal : _ output -> _ output -> bool
end
(**/**)
(**{6 Internals}*)
external noop : unit -> unit = "%ignore"
(**
{7 Optimized access to fields}
*)
val get_output : _ output -> (string -> int -> int -> int)
val get_flush : _ output -> (unit -> unit)
val lock : BatConcurrent.lock ref
(**
A reference to a set of locking operations.
*)
(**
{7 Facilities for debugging}
*)
val get_output_id : _ output -> int
val get_input_id : input -> int
(**/**)
|