Copyright | (c) Henning Thielemann 2007-2010 |
---|---|

Maintainer | haskell@henning-thielemann.de |

Stability | stable |

Portability | Haskell 98 |

Safe Haskell | Safe |

Language | Haskell98 |

A type for non-negative numbers.
It performs a run-time check at construction time (i.e. at run-time)
and is a member of the non-negative number type class
`C`

.

- data T a
- fromNumber :: (Ord a, Num a) => a -> T a
- fromNumberMsg :: (Ord a, Num a) => String -> a -> T a
- fromNumberClip :: (Ord a, Num a) => a -> T a
- fromNumberUnsafe :: a -> T a
- toNumber :: T a -> a
- type Int = T Int
- type Integer = T Integer
- type Float = T Float
- type Double = T Double
- type Ratio a = T (Ratio a)
- type Rational = T Rational

# Documentation

(Ord a, Num a, Bounded a) => Bounded (T a) Source # | |

(Ord a, Num a, Enum a) => Enum (T a) Source # | |

Eq a => Eq (T a) Source # | |

(Ord a, Floating a) => Floating (T a) Source # | |

(Ord a, Fractional a) => Fractional (T a) Source # | |

Integral a => Integral (T a) Source # | |

(Ord a, Num a) => Num (T a) Source # | |

Ord a => Ord (T a) Source # | |

Real a => Real (T a) Source # | |

RealFrac a => RealFrac (T a) Source # | |

Show a => Show (T a) Source # | |

Num a => Monoid (T a) Source # | |

(Num a, Arbitrary a) => Arbitrary (T a) Source # | |

(Ord a, Num a) => C (T a) Source # | |

fromNumber :: (Ord a, Num a) => a -> T a Source #

Convert a number to a non-negative number. If a negative number is given, an error is raised.

fromNumberClip :: (Ord a, Num a) => a -> T a Source #

Convert a number to a non-negative number. A negative number will be replaced by zero. Use this function with care since it may hide bugs.

fromNumberUnsafe :: a -> T a Source #

Wrap a number into a non-negative number without doing checks. This routine exists entirely for efficiency reasons and must be used only in cases where you are absolutely sure, that the input number is non-negative.