Copyright | (c) The University of Glasgow 1994-2009 |
---|---|
License | see libraries/base/LICENSE |
Maintainer | [email protected] |
Stability | internal |
Portability | non-portable |
Safe Haskell | Trustworthy |
Language | Haskell2010 |
Basic types for the implementation of IO Handles.
Haskell defines operations to read and write characters from and to files, represented by values of type Handle
. Each value of this type is a handle: a record used by the Haskell run-time system to manage I/O with file system objects. A handle has at least the following properties:
Most handles will also have a current I/O position indicating where the next input or output operation will occur. A handle is readable if it manages only input or both input and output; likewise, it is writable if it manages only output or both input and output. A handle is open when first allocated. Once it is closed it can no longer be used for either input or output, though an implementation cannot re-use its storage while references remain to it. Handles are in the Show
and Eq
classes. The string produced by showing a handle is system dependent; it should include enough information to identify the handle for debugging. A handle is equal according to ==
only to itself; no attempt is made to compare the internal state of different handles for equality.
FileHandle FilePath !(MVar Handle__) | |
DuplexHandle FilePath !(MVar Handle__) !(MVar Handle__) |
forall dev enc_state dec_state.(IODevice dev, BufferedIO dev, Typeable dev) => Handle__ | |
Fields
|
showHandle :: FilePath -> String -> String Source
checkHandleInvariants :: Handle__ -> IO () Source
data BufferList e Source
BufferListNil | |
BufferListCons (RawBuffer e) (BufferList e) |
data HandleType Source
Show HandleType | Since: base-4.1.0.0 |
Defined in GHC.IO.Handle.Types MethodsshowsPrec :: Int -> HandleType -> ShowS Source show :: HandleType -> String Source showList :: [HandleType] -> ShowS Source |
isReadableHandleType :: HandleType -> Bool Source
isWritableHandleType :: HandleType -> Bool Source
isReadWriteHandleType :: HandleType -> Bool Source
data BufferMode Source
Three kinds of buffering are supported: line-buffering, block-buffering or no-buffering. These modes have the following effects. For output, items are written out, or flushed, from the internal buffer according to the buffer mode:
hFlush
is issued, or the handle is closed.hFlush
is issued, or the handle is closed.An implementation is free to flush the buffer more frequently, but not less frequently, than specified above. The output buffer is emptied as soon as it has been written out.
Similarly, input occurs according to the buffer mode for the handle:
hLookAhead
operation implies that even a no-buffered handle may require a one-character buffer.The default buffering mode when a handle is opened is implementation-dependent and may depend on the file system object which is attached to that handle. For most implementations, physical files will normally be block-buffered and terminals will normally be line-buffered.
NoBuffering | buffering is disabled if possible. |
LineBuffering | line-buffering should be enabled if possible. |
BlockBuffering (Maybe Int) | block-buffering should be enabled if possible. The size of the buffer is |
Eq BufferMode | Since: base-4.2.0.0 |
Defined in GHC.IO.Handle.Types Methods(==) :: BufferMode -> BufferMode -> Bool Source (/=) :: BufferMode -> BufferMode -> Bool Source | |
Ord BufferMode | Since: base-4.2.0.0 |
Defined in GHC.IO.Handle.Types Methodscompare :: BufferMode -> BufferMode -> Ordering Source (<) :: BufferMode -> BufferMode -> Bool Source (<=) :: BufferMode -> BufferMode -> Bool Source (>) :: BufferMode -> BufferMode -> Bool Source (>=) :: BufferMode -> BufferMode -> Bool Source max :: BufferMode -> BufferMode -> BufferMode Source min :: BufferMode -> BufferMode -> BufferMode Source | |
Read BufferMode | Since: base-4.2.0.0 |
Defined in GHC.IO.Handle.Types MethodsreadsPrec :: Int -> ReadS BufferMode Source readList :: ReadS [BufferMode] Source | |
Show BufferMode | Since: base-4.2.0.0 |
Defined in GHC.IO.Handle.Types MethodsshowsPrec :: Int -> BufferMode -> ShowS Source show :: BufferMode -> String Source showList :: [BufferMode] -> ShowS Source |
data BufferCodec from to state Source
BufferCodec | |
Fields
|
data NewlineMode Source
Specifies the translation, if any, of newline characters between internal Strings and the external file or stream. Haskell Strings are assumed to represent newlines with the '\n'
character; the newline mode specifies how to translate '\n'
on output, and what to translate into '\n'
on input.
NewlineMode | |
Eq NewlineMode | Since: base-4.2.0.0 |
Defined in GHC.IO.Handle.Types Methods(==) :: NewlineMode -> NewlineMode -> Bool Source (/=) :: NewlineMode -> NewlineMode -> Bool Source | |
Ord NewlineMode | Since: base-4.3.0.0 |
Defined in GHC.IO.Handle.Types Methodscompare :: NewlineMode -> NewlineMode -> Ordering Source (<) :: NewlineMode -> NewlineMode -> Bool Source (<=) :: NewlineMode -> NewlineMode -> Bool Source (>) :: NewlineMode -> NewlineMode -> Bool Source (>=) :: NewlineMode -> NewlineMode -> Bool Source max :: NewlineMode -> NewlineMode -> NewlineMode Source min :: NewlineMode -> NewlineMode -> NewlineMode Source | |
Read NewlineMode | Since: base-4.3.0.0 |
Defined in GHC.IO.Handle.Types MethodsreadsPrec :: Int -> ReadS NewlineMode Source readList :: ReadS [NewlineMode] Source | |
Show NewlineMode | Since: base-4.3.0.0 |
Defined in GHC.IO.Handle.Types MethodsshowsPrec :: Int -> NewlineMode -> ShowS Source show :: NewlineMode -> String Source showList :: [NewlineMode] -> ShowS Source |
The representation of a newline in the external file or stream.
Eq Newline | Since: base-4.2.0.0 |
Ord Newline | Since: base-4.3.0.0 |
Read Newline | Since: base-4.3.0.0 |
Show Newline | Since: base-4.3.0.0 |
nativeNewline :: Newline Source
The native newline representation for the current platform: LF
on Unix systems, CRLF
on Windows.
universalNewlineMode :: NewlineMode Source
Map '\r\n'
into '\n'
on input, and '\n'
to the native newline represetnation on output. This mode can be used on any platform, and works with text files using any newline convention. The downside is that readFile >>= writeFile
might yield a different file.
universalNewlineMode = NewlineMode { inputNL = CRLF, outputNL = nativeNewline }
noNewlineTranslation :: NewlineMode Source
Do no newline translation at all.
noNewlineTranslation = NewlineMode { inputNL = LF, outputNL = LF }
nativeNewlineMode :: NewlineMode Source
Use the native newline representation on both input and output
nativeNewlineMode = NewlineMode { inputNL = nativeNewline outputNL = nativeNewline }
© The University of Glasgow and others
Licensed under a BSD-style license (see top of the page).
https://downloads.haskell.org/~ghc/8.8.3/docs/html/libraries/base-4.13.0.0/GHC-IO-Handle-Types.html