module IO: BatIOtypeinput =BatInnerIO.input
type'aoutput ='a BatInnerIO.output
'a is the accumulator data, it is returned
    when the close_out function is called.type('a, 'b)printer ='b output -> 'a -> unit
'a to an output that
    produces 'b as result.type'af_printer =Format.formatter -> 'a -> unit
exception No_more_input
read or
    nread functions while there is no available token to read.exception Input_closed
exception Output_closed
val stdin : input
    Example: if read_line stdin |> Int.of_string > 10 then failwith "too big a number read"; 
val stdout : unit output
    Use this output to display regular messages.
    Example: 
       write_string stdout "Enter your name:";
       let name = read_line stdin in
       write_line stdout ("Your name is " ^ name);
    
val stderr : unit outputUse this output to display warnings and error messages.
    Example: 
       write_line stderr "Error on Internet - please delete google.com";
    
val stdnull : unit outputUse this output to ignore messages.
    Example: 
      let out_ch = if debug then stderr else stdnull in
      write_line out_ch "Program running.";
    
val read : input -> charNo_more_input if
    no input is available.
    Example: let rec skip_line ch = if read ch = '\n' then skip_line ch else ();
val nread : input -> int -> stringnread 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.
    Example: let read_md5 ch = nread ch 32
val really_nread : input -> int -> stringreally_nread i n reads a string of exactly n characters
    from the input.No_more_input if at least n characters are
    not available.Invalid_argument if n < 0.
    Example: let read_md5 ch = really_nread ch 32
val input : input -> string -> int -> int -> intinput 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 (which may be 0) 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.
    Example: let map_ch f ?(block_size=100) =
    let b = String.create block_size in
    try while true do
      let l = input ch b 0 block_size in
      f b 0 l;
    done with No_more_input -> ()
val really_input : input -> string -> int -> int -> intreally_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.No_more_input if at l characters are not
    available.Invalid_argument if p and l do not
    designate a valid substring of s.
    Example: let _ = really_input stdin b 0 3
val close_in : input -> unit
    Example: close_in network_in;
val write : (char, 'a) printer
    Example: write stdout 'x';
val nwrite : (string, 'a) printer
    Example: nwrite stdout "Enter your name: ";
val output : 'a output -> string -> int -> int -> intoutput 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.
    Example: let str = "Foo Bar Baz" in let written = output stdout str 2 4;
    This writes "o Ba" to stdout.
val really_output : 'a output -> string -> int -> int -> intreally_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.Invalid_argument if p and l do not
    designate a valid substring of s.
    This function is useful for networking situations where the output
    buffer might fill resulting in not the entire substring being
    readied for transmission.  Uses output internally, and will
    raise Sys_blocked_io in the case that any call returns 0.
val flush : 'a output -> unitIf previous write operations have caused errors, this may trigger an exception.
    Example: flush stdout;
val flush_all : unit -> unit
    Example: flush_all ();
val close_out : 'a output -> 'aThe output is flushed before being closed and can no longer be written. Attempting to flush or write after the output has been closed will have no effect.
    Example: 
    let strout = output_string () in
    write strout 'x';
    if 2+3>5 then write strout "y";
    print_string (close_out strout) 
    To open a file for reading/writing, see File.open_in
    and File.open_out
val input_string : string -> input
    Example: 
    let inch = input_string "1234554321" in
    let str1 = nread inch 3 in (* "123" *)
    let str2 = nread inch 5 in (* "45543" *)
    let str3 = nread inch 2 in (* "21" *)
    try string_of_char(read inch) with BatIO.No_more_input -> "End of string";
    
val output_string : unit -> string outputval input_enum : char BatEnum.t -> inputenum.val output_enum : unit -> char BatEnum.t outputenum. The
    final enum is returned when the output is closed.val combine : 'a output * 'b output -> ('a * 'b) outputcombine (a,b) creates a new output c such that
    writing to c will actually write to both a and bval tab_out : ?tab:char -> int -> 'a output -> unit outputtab).
    tab_out n out produces a new output for writing into out, in
    which every new line starts with n spaces.
Raises Invalid_argument if n < 0.
    Closing tab_out n out does not close out. Rather,
    closing out closes tab_out n out.
val read_all : input -> stringNo_more_input is raised.val pipe : unit -> input * unit outputval copy : ?buffer:int -> input -> 'a output -> unitbuffer : The size of the buffer to use for copying, in
    bytes. By default, this is 4,096b.val pos_in : input -> input * (unit -> int)val progress_in : input -> (unit -> unit) -> inputprogress_in inp f create an input that calls f ()
    whenever some content is succesfully read from it.val pos_out : 'a output -> unit output * (unit -> int)val progress_out : 'a output -> (unit -> unit) -> unit outputprogress_out out f create an output that calls f ()
    whenever some content is succesfully written to it.val cast_output : 'a output -> unit output
    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 BatIO.BigEndian module provide multibyte
    operations with other encoding.
exception Overflow of string
val read_byte : input -> intval read_signed_byte : input -> intval read_ui16 : input -> intval read_i16 : input -> intval read_i32 : input -> intOverflow if the
    read integer cannot be represented as an OCaml 31-bit integer.val read_real_i32 : input -> int32val read_i64 : input -> int64val read_float : input -> floatval read_double : input -> floatval read_string : input -> stringval read_line : input -> stringNo_more_input only if no characters are available.val write_byte : (int, 'a) printerval write_ui16 : (int, 'a) printerval write_i16 : (int, 'a) printerval write_i32 : (int, 'a) printerval write_real_i32 : (int32, 'a) printerval write_i64 : (int64, 'a) printerval write_double : (float, 'a) printerval write_float : (float, 'a) printerval write_string : (string, 'a) printerval write_line : (string, 'a) printer
    This adds the correct line end for your operating system.  That
    is, if you are writing to a file and your system imposes that
    files should end lines with character LF (or '\n'), as Unix,
    then a LF is inserted at the end of the line. If your system
    favors CRLF (or '\r\n'), then this is what will be inserted.
module BigEndian:sig..end
BatIO, but with big-endian encoding
    This enable you to read and write from an BatIO bit-by-bit or several bits
    at the same time.
type 
type 
exception Bits_error
val input_bits : input -> in_bitsval output_bits : 'a output -> out_bitsval read_bits : in_bits -> int -> intval write_bits : out_bits -> nbits:int -> int -> unitval flush_bits : out_bits -> unitval drop_bits : in_bits -> unitval create_in : read:(unit -> char) ->
       input:(string -> int -> int -> int) -> close:(unit -> unit) -> input
    Note Do not use this function for creating an input
    which reads from one or more underlying inputs. Rather, use
    BatIO.wrap_in.
val wrap_in : read:(unit -> char) ->
       input:(string -> int -> int -> int) ->
       close:(unit -> unit) -> underlying:input list -> input
    This function is a more general version of BatIO.create_in
    which also handles dependency management between inputs.
    Note When you create an input which reads from another
    input, function close should not close the inputs of
    underlying. Doing so is a common error, which could result
    in inadvertently closing BatIO.stdin or a network socket, etc.
val inherit_in : ?read:(unit -> char) ->
       ?input:(string -> int -> int -> int) ->
       ?close:(unit -> unit) -> input -> inputBatIO.wrap_in which may be used
    whenever only one input appears as dependency.
    inherit_in inp will return an input identical to inp.
    inherit_in ~read inp will return an input identical to
    inp except for method read, etc.
    You do not need to close inp in close.
val create_out : write:(char -> unit) ->
       output:(string -> int -> int -> int) ->
       flush:(unit -> unit) -> close:(unit -> 'a) -> 'a outputwrite : Write one character to the output (see BatIO.write).output : Write a (sub)string to the output (see BatIO.output).flush : Flush any buffers of this output  (see BatIO.flush).close : Close this output. The output will be automatically
    flushed.
    Note Do not use this function for creating an output which
    writes to one or more underlying outputs. Rather, use BatIO.wrap_out.
val wrap_out : write:(char -> unit) ->
       output:(string -> int -> int -> int) ->
       flush:(unit -> unit) ->
       close:(unit -> 'a) -> underlying:'b output list -> 'a output
   This function is a more general version of BatIO.create_out,
   which also handles dependency management between outputs.
To illustrate the need for dependency management, let us consider the following values:
outf : _ output -> _ output, using BatIO.create_out to
   create a new output for writing some data to an underyling
   output (for instance, a function comparale to BatIO.tab_out or a
   function performing transparent compression or transparent
   traduction between encodings)f out is createdf out but not flushedout is closed, perhaps manually or as a consequence
   of garbage-collection, or because the program has endedf out is flushed.out only after out has been closed.
   Despite appearances, it is quite easy to reach such situation,
   especially in short programs.
   If, instead, f uses wrap_out, then when output out is closed,
   f out is first automatically flushed and closed, which avoids the
   issue.
write : Write one character to the output (see BatIO.write).output : Write a (sub)string to the output (see BatIO.output).flush : Flush any buffers of this output  (see BatIO.flush).close : Close this output. The output will be automatically
   flushed.underlying : The list of outputs to which the new output will
   write.
   Note Function close should 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 inherit_out : ?write:(char -> unit) ->
       ?output:(string -> int -> int -> int) ->
       ?flush:(unit -> unit) ->
       ?close:(unit -> unit) -> 'a output -> unit outputBatIO.wrap_out whenever only
   one output appears as dependency.
   inherit_out out will return an output identical to out.
   inherit_out ~write out will return an output identical to
   out except for its write method, etc.
   You do not need to close out in close.
val input_channel : ?autoclose:bool -> ?cleanup:bool -> Pervasives.in_channel -> inputautoclose : If true or unspecified, the BatIO.input
    will be automatically closed when the underlying in_channel
    has reached its end.cleanup : If true, the channel
    will be automatically closed when the BatIO.input is closed.
    Otherwise, you will need to close the channel manually.val output_channel : ?cleanup:bool -> Pervasives.out_channel -> unit outputcleanup : If true, the channel
    will be automatically closed when the BatIO.output is closed.
    Otherwise, you will need to close the channel manually.val to_input_channel : input -> Pervasives.in_channel
    Note This function is extremely 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.
    Theses OO Wrappers have been written to provide easy support of
    BatIO by external librairies. If you want your library to support
    BatIO without actually requiring Batteries to compile, you can
    should implement the classes in_channel, out_channel,
    poly_in_channel and/or poly_out_channel which are the common
    BatIO specifications established for ExtLib, OCamlNet and
    Camomile.
(see http://www.ocaml-programming.de/tmp/BatIO-Classes.html for more details).
    Note In this version of Batteries Included, the object wrappers are not
    closed automatically by garbage-collection.
class in_channel :input ->object..end
class out_channel :'a output ->object..end
class in_chars :input ->object..end
class out_chars :'a output ->object..end
val from_in_channel : #in_channel -> input
val from_out_channel : #out_channel -> unit output
val from_in_chars : #in_chars -> input
val from_out_chars : #out_chars -> unit outputval bytes_of : input -> int BatEnum.tval signed_bytes_of : input -> int BatEnum.tval ui16s_of : input -> int BatEnum.tval i16s_of : input -> int BatEnum.tval i32s_of : input -> int BatEnum.tOverflow if the
    read integer cannot be represented as an OCaml 31-bit integer.val real_i32s_of : input -> int32 BatEnum.tint32s.val i64s_of : input -> int64 BatEnum.tint64s.val doubles_of : input -> float BatEnum.tval floats_of : input -> float BatEnum.tval strings_of : input -> string BatEnum.tval lines_of : input -> string BatEnum.tval lines_of2 : input -> string BatEnum.t
val chunks_of : int -> input -> string BatEnum.tval chars_of : input -> char BatEnum.t
    Note Usually faster than calling read several times.
val bits_of : in_bits -> int BatEnum.tval write_bitss : nbits:int -> out_bits -> int BatEnum.t -> unitval default_buffer_size : intval synchronize_in : ?lock:BatConcurrent.lock -> input -> inputsynchronize_in inp produces a new BatIO.input which reads from input
   in a thread-safe way. In other words, a lock prevents two distinct threads
   from reading from that input simultaneously, something which would potentially
   wreak havoc otherwiselock : An optional lock. If none is provided, the lock will be specific
   to this input. Specifiying a custom lock may be useful to associate one
   common lock for several inputs and/or outputs, for instance in the case
   of pipes.val synchronize_out : ?lock:BatConcurrent.lock -> 'a output -> unit outputsynchronize_out out produces a new BatIO.output which writes to output
   in a thread-safe way. In other words, a lock prevents two distinct threads
   from writing to that output simultaneously, something which would potentially
   wreak havoc otherwiselock : An optional lock. If none is provided, the lock will be specific
   to this output. Specifiying a custom lock may be useful to associate one
   common lock for several inputs and/or outputs, for instance in the case
   of pipes.
   Unless you are attempting to adapt Batteries Included to a new model of
   concurrency, you probably won't need this.
val lock : BatConcurrent.lock Pervasives.ref
   By default, this is BatConcurrent.nolock. However, if you're
   using a version of Batteries compiled in threaded mode, this uses
   BatMutex. If you're attempting to use Batteries with another
   concurrency model, set the lock appropriately.
val lock_factory : (unit -> BatConcurrent.lock) Pervasives.refBatIO.synchronize_in
   and BatIO.synchronize_out.
   By default, this always returns BatConcurrent.nolock. However,
   if you're using a version of Batteries compiled in threaded mode,
   this uses BatMutex.
val to_string : ('a, string) printer -> 'a -> string
val to_f_printer : ('a, 'b) printer -> 'a f_printer