| Safe Haskell | Safe |
|---|---|
| Language | Haskell2010 |
Text.Read.Bounded
Description
Class for reading bounded values.
Synopsis
- data BoundedRead a
- = NoRead
- | ExactRead a
- | ClampedRead a
- class ReadBounded a where
- readBounded :: String -> BoundedRead a
- readBoundedInteger :: (Bounded a, Read a, Integral a) => String -> BoundedRead a
Documentation
data BoundedRead a Source #
Information about a bounded read.
Constructors
| NoRead | The read failed. |
| ExactRead a | The value was successfully read exactly, and did not have to be clamped to a narrower representation. |
| ClampedRead a | The value was successfully read, but had to be clamped to a narrower representation because its value was too wide. |
Instances
class ReadBounded a where Source #
Much like the Read class, but will return (possibly) clamped values.
Typical instances of this class will clamp against minBound and maxBound
This class is designed to avoid inconsistency problems such as the following:
>>>read "321" :: Word865>>>read "4321" :: Word8225>>>read "-4" :: Word8252
Using this class, the results are predictable and precise:
>>>readBounded "321" :: BoundedRead Word8ClampedRead 255>>>readBounded "4321" :: BoundedRead Word8ClampedRead 255>>>readBounded "-4" :: BoundedRead Word8ClampedRead 0>>>readBounded "255" :: BoundedRead Word8ExactRead 255>>>readBounded "6" :: BoundedRead Word8ExactRead 6>>>readBounded "xxx" :: BoundedRead Word8NoRead
Methods
readBounded :: String -> BoundedRead a Source #
Instances
readBoundedInteger :: (Bounded a, Read a, Integral a) => String -> BoundedRead a Source #
Reads a clamped value for any integer type with the given class constraints.
Useful for implementing a ReadBounded instance or avoiding one.