Structure BinIO
(* BinIO -- SML Basis Library *)
type elem = Word8.word
type vector = Word8Vector.vector
(* Binary input *)
type instream
val openIn : string -> instream
val closeIn : instream -> unit
val input : instream -> vector
val inputAll : instream -> vector
val inputNoBlock : instream -> vector option
val input1 : instream -> elem option
val inputN : instream * int -> vector
val endOfStream : instream -> bool
val lookahead : instream -> elem option
(* Binary output *)
type outstream
val openOut : string -> outstream
val openAppend : string -> outstream
val closeOut : outstream -> unit
val output : outstream * vector -> unit
val output1 : outstream * elem -> unit
val flushOut : outstream -> unit
(*
This structure provides input/output functions on byte streams.
The functions are state-based: reading from or writing to a stream
changes the state of the stream. The streams are buffered: output
to a stream may not immediately affect the underlying file or
device.
[instream] is the type of state-based byte input streams.
[outstream] is the type of state-based byte output streams.
[elem] is the type Word8.word of bytes.
[vector] is the type of Word8Vector.vector (byte vectors).
BYTE INPUT:
[openIn s] creates a new instream associated with the file named s.
Raises Io.Io is file s does not exist or is not accessible.
[closeIn istr] closes stream istr. Has no effect if istr is closed
already. Further operations on istr will behave as if istr is at
end of stream (that is, will return "" or NONE or true).
[input istr] reads some elements from istr, returning a vector v of
those elements. The vector will be empty (size v = 0) if and only
if istr is at end of stream or is closed. May block (not return
until data are available in the external world).
[inputAll istr] reads and returns the vector v of all bytes
remaining in istr up to end of stream.
[inputNoBlock istr] returns SOME(v) if some elements v can be read
without blocking; returns SOME("") if it can be determined without
blocking that istr is at end of stream; returns NONE otherwise. If
istr does not support non-blocking input, raises
Io.NonblockingNotSupported.
[input1 istr] returns SOME(e) if at least one element e of istr is
available; returns NONE if istr is at end of stream or is closed;
blocks if necessary until one of these conditions holds.
[inputN(istr, n)] returns the next n bytes from istr as a vector,
if that many are available; returns all remaining bytes if end of
stream is reached before n bytes are available; blocks if necessary
until one of these conditions holds.
[endOfStream istr] returns false if any elements are available in
istr; returns true if istr is at end of stream or closed; blocks if
necessary until one of these conditions holds.
[lookahead istr] returns SOME(e) where e is the next element in the
stream; returns NONE if istr is at end of stream or is closed;
blocks if necessary until one of these conditions holds. Does not
advance the stream.
BYTE OUTPUT:
[openOut s] creates a new outstream associated with the file named
s. If file s does not exist, and the directory exists and is
writable, then a new file is created. If file s exists, it is
truncated (any existing contents are lost).
[openAppend s] creates a new outstream associated with the file
named s. If file s does not exist, and the directory exists and is
writable, then a new file is created. If file s exists, any
existing contents are retained, and output goes at the end of the
file.
[closeOut ostr] closes stream ostr; further operations on ostr
(except for additional close operations) will raise exception Io.Io.
[output(ostr, v)] writes the byte vector v on outstream ostr.
[output1(ostr, e)] writes the byte e on outstream ostr.
[flushOut ostr] flushes the outstream ostr, so that all data
written to ostr becomes available to the underlying file or device.
The functions below are not yet implemented:
[setPosIn(istr, i)] sets istr to the position i. Raises Io.Io if
not supported on istr.
[getPosIn istr] returns the current position of istr. Raises Io.Io
if not supported on istr.
[endPosIn istr] returns the last position of istr.
[getPosOut ostr] returns the current position in stream ostr.
Raises Io.Io if not supported on ostr.
[endPosOut ostr] returns the ending position in stream ostr.
Raises Io.Io if not supported on ostr.
[setPosOut(ostr, i)] sets the current position in stream to ostr to
i. Raises Io.Io if not supported on ostr.
[mkInstream sistr] creates a state-based instream from the
functional instream sistr.
[getInstream istr] returns the functional instream underlying the
state-based instream istr.
[setInstream(istr, sistr)] redirects istr, so that subsequent input
is taken from the functional instream sistr.
[mkOutstream sostr] creates a state-based outstream from the
outstream sostr.
[getOutstream ostr] returns the outstream underlying the
state-based outstream ostr.
[setOutstream(ostr, sostr)] redirects the outstream ostr so that
subsequent output goes to sostr.
*)
Moscow ML 2.00