diff options
| author | Don Stewart <dons@galois.com> | 2008-03-08 01:24:57 +0000 |
|---|---|---|
| committer | Don Stewart <dons@galois.com> | 2008-03-08 01:24:57 +0000 |
| commit | b7703a47420a6395d0e550eb23c19810bcff9ff6 (patch) | |
| tree | 581a6c1bbef14e12b2e7ea56d8b5bc8699e2b91c /libraries/base/Control/Monad/Fix.hs | |
| parent | 0b0b3acb2f0b303fcede948dfea17d38b7bd7a42 (diff) | |
| download | haskell-b7703a47420a6395d0e550eb23c19810bcff9ff6.tar.gz | |
untabify
Diffstat (limited to 'libraries/base/Control/Monad/Fix.hs')
| -rw-r--r-- | libraries/base/Control/Monad/Fix.hs | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/libraries/base/Control/Monad/Fix.hs b/libraries/base/Control/Monad/Fix.hs index 6196f737ba..d0582200ed 100644 --- a/libraries/base/Control/Monad/Fix.hs +++ b/libraries/base/Control/Monad/Fix.hs @@ -2,7 +2,7 @@ -- | -- Module : Control.Monad.Fix -- Copyright : (c) Andy Gill 2001, --- (c) Oregon Graduate Institute of Science and Technology, 2002 +-- (c) Oregon Graduate Institute of Science and Technology, 2002 -- License : BSD-style (see the file libraries/base/LICENSE) -- Maintainer : libraries@haskell.org -- Stability : experimental @@ -16,10 +16,10 @@ ----------------------------------------------------------------------------- module Control.Monad.Fix ( - MonadFix( - mfix -- :: (a -> m a) -> m a + MonadFix( + mfix -- :: (a -> m a) -> m a ), - fix -- :: (a -> a) -> a + fix -- :: (a -> a) -> a ) where import Prelude @@ -35,26 +35,26 @@ import Hugs.Prelude (MonadFix(mfix)) -- Instances of 'MonadFix' should satisfy the following laws: -- -- [/purity/] --- @'mfix' ('return' . h) = 'return' ('fix' h)@ +-- @'mfix' ('return' . h) = 'return' ('fix' h)@ -- -- [/left shrinking/ (or /tightening/)] --- @'mfix' (\\x -> a >>= \\y -> f x y) = a >>= \\y -> 'mfix' (\\x -> f x y)@ +-- @'mfix' (\\x -> a >>= \\y -> f x y) = a >>= \\y -> 'mfix' (\\x -> f x y)@ -- -- [/sliding/] --- @'mfix' ('Control.Monad.liftM' h . f) = 'Control.Monad.liftM' h ('mfix' (f . h))@, --- for strict @h@. +-- @'mfix' ('Control.Monad.liftM' h . f) = 'Control.Monad.liftM' h ('mfix' (f . h))@, +-- for strict @h@. -- -- [/nesting/] --- @'mfix' (\\x -> 'mfix' (\\y -> f x y)) = 'mfix' (\\x -> f x x)@ +-- @'mfix' (\\x -> 'mfix' (\\y -> f x y)) = 'mfix' (\\x -> f x x)@ -- -- This class is used in the translation of the recursive @do@ notation -- supported by GHC and Hugs. class (Monad m) => MonadFix m where - -- | The fixed point of a monadic computation. - -- @'mfix' f@ executes the action @f@ only once, with the eventual - -- output fed back as the input. Hence @f@ should not be strict, - -- for then @'mfix' f@ would diverge. - mfix :: (a -> m a) -> m a + -- | The fixed point of a monadic computation. + -- @'mfix' f@ executes the action @f@ only once, with the eventual + -- output fed back as the input. Hence @f@ should not be strict, + -- for then @'mfix' f@ would diverge. + mfix :: (a -> m a) -> m a #endif /* !__HUGS__ */ -- Instances of MonadFix for Prelude monads |
