-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/
-- | A collection of monad transformers.
--
-- A collection of monad transformers.
@package monadLib
@version 3.3.0
-- | This library provides a collection of monad transformers that can be
-- combined to produce various monads.
module MonadLib
-- | Computations with no effects.
data Id a
-- | Computation with no effects (strict).
data Lift a
-- | Add nothing. Useful as a placeholder.
data IdT m a
-- | Add support for propagating a context.
data ReaderT i m a
-- | Add support for collecting values.
data WriterT i m a
-- | Add support for threading state.
data StateT i m a
-- | Add support for exceptions.
data ExceptionT i m a
-- | Add support for jumps.
data ContT i m a
class MonadT t
lift :: (MonadT t, Monad m) => m a -> t m a
class (Monad m, Monad n) => BaseM m n | m -> n
inBase :: (BaseM m n) => n a -> m a
-- | Classifies monads that provide access to a context of type i.
class (Monad m) => ReaderM m i | m -> i
ask :: (ReaderM m i) => m i
-- | Classifies monads that can collect values of type i.
class (Monad m) => WriterM m i | m -> i
put :: (WriterM m i) => i -> m ()
-- | Classifies monads that propagate a state component of type i.
class (Monad m) => StateM m i | m -> i
get :: (StateM m i) => m i
set :: (StateM m i) => i -> m ()
-- | Classifies monads that support raising exceptions of type i.
class (Monad m) => ExceptionM m i | m -> i
raise :: (ExceptionM m i) => i -> m a
-- | Classifies monads that provide access to a computation's continuation.
class (Monad m) => ContM m
callCC :: (ContM m) => ((a -> m b) -> m a) -> m a
-- | An explicit representation for continuations that store a value.
data Label m a
-- | Capture the current continuation This function is like return,
-- except that it also captures the current continuation. Later we can
-- use jump to go back to the continuation with a possibly
-- different value.
labelCC :: (ContM m) => a -> m (a, Label m a)
-- | Change the value passed to a previously captured continuation.
jump :: (ContM m) => a -> Label m a -> m b
-- | Get the result of a pure computation.
runId :: Id a -> a
-- | Get the result of a pure strict computation.
runLift :: Lift a -> a
-- | Remove an identity layer.
runIdT :: IdT m a -> m a
-- | Execute a reader computation in the given context.
runReaderT :: i -> ReaderT i m a -> m a
-- | Execute a writer computation. Returns the result and the collected
-- output.
runWriterT :: WriterT i m a -> m (a, i)
-- | Execute a stateful computation in the given initial state. The second
-- component of the result is the final state.
runStateT :: i -> StateT i m a -> m (a, i)
-- | Execute a computation with exceptions. Successful results are tagged
-- with Right, exceptional results are tagged with Left.
runExceptionT :: ExceptionT i m a -> m (Either i a)
-- | Execute a computation with the given continuation.
runContT :: (a -> m i) -> ContT i m a -> m i
-- | Classifies monads that support changing the context for a
-- sub-computation.
class (ReaderM m i) => RunReaderM m i | m -> i
local :: (RunReaderM m i) => i -> m a -> m a
-- | Classifies monads that support collecting the output of a
-- sub-computation.
class (WriterM m i) => RunWriterM m i | m -> i
collect :: (RunWriterM m i) => m a -> m (a, i)
-- | Classifies monads that support handling of exceptions.
class (ExceptionM m i) => RunExceptionM m i | m -> i
try :: (RunExceptionM m i) => m a -> m (Either i a)
-- | A isomorphism between (usually) monads. Typically the constructor and
-- selector of a newtype delcaration.
data Iso m n
Iso :: (forall a. m a -> n a) -> (forall a. n a -> m a) -> Iso m n
close :: Iso m n -> forall a. m a -> n a
open :: Iso m n -> forall a. n a -> m a
-- | Derive the implementation of fmap from Functor.
derive_fmap :: (Functor m) => Iso m n -> (a -> b) -> n a -> n b
-- | Derive the implementation of return from Monad.
derive_return :: (Monad m) => Iso m n -> (a -> n a)
-- | Derive the implementation of >>= from Monad.
derive_bind :: (Monad m) => Iso m n -> n a -> (a -> n b) -> n b
derive_fail :: (Monad m) => Iso m n -> String -> n a
-- | Derive the implementation of mfix from MonadFix.
derive_mfix :: (MonadFix m) => Iso m n -> (a -> n a) -> n a
-- | Derive the implementation of ask from ReaderM.
derive_ask :: (ReaderM m i) => Iso m n -> n i
-- | Derive the implementation of put from WriterM.
derive_put :: (WriterM m i) => Iso m n -> i -> n ()
-- | Derive the implementation of get from StateM.
derive_get :: (StateM m i) => Iso m n -> n i
-- | Derive the implementation of set from StateM.
derive_set :: (StateM m i) => Iso m n -> i -> n ()
-- | Derive the implementation of raise from ExceptionM.
derive_raise :: (ExceptionM m i) => Iso m n -> i -> n a
-- | Derive the implementation of callCC from ContM.
derive_callCC :: (ContM m) => Iso m n -> ((a -> n b) -> n a) -> n a
-- | Derive the implementation of local from RunReaderM.
derive_local :: (RunReaderM m i) => Iso m n -> i -> n a -> n a
-- | Derive the implementation of collect from RunWriterM.
derive_collect :: (RunWriterM m i) => Iso m n -> n a -> n (a, i)
-- | Derive the implementation of try from RunExceptionM.
derive_try :: (RunExceptionM m i) => Iso m n -> n a -> n (Either i a)
derive_lift :: (MonadT t, Monad m) => Iso (t m) n -> m a -> n a
derive_inBase :: (BaseM m x) => Iso m n -> x a -> n a
-- | The current version of the library.
version :: (Int, Int, Int)
instance (Monad m) => RunExceptionM (ExceptionT i m) i
instance (RunExceptionM m i) => RunExceptionM (StateT j m) i
instance (RunExceptionM m i, Monoid j) => RunExceptionM (WriterT j m) i
instance (RunExceptionM m i) => RunExceptionM (ReaderT j m) i
instance (RunExceptionM m i) => RunExceptionM (IdT m) i
instance (RunWriterM m j) => RunWriterM (ExceptionT i m) j
instance (RunWriterM m j) => RunWriterM (StateT i m) j
instance (Monad m, Monoid i) => RunWriterM (WriterT i m) i
instance (RunWriterM m j) => RunWriterM (ReaderT i m) j
instance (RunWriterM m j) => RunWriterM (IdT m) j
instance (RunReaderM m j) => RunReaderM (ExceptionT i m) j
instance (RunReaderM m j) => RunReaderM (StateT i m) j
instance (RunReaderM m j, Monoid i) => RunReaderM (WriterT i m) j
instance (RunReaderM m j) => RunReaderM (IdT m) j
instance (Monad m) => RunReaderM (ReaderT i m) i
instance (Monad m) => ContM (ContT i m)
instance (ContM m) => ContM (ExceptionT i m)
instance (ContM m, Monoid i) => ContM (WriterT i m)
instance (ContM m) => ContM (StateT i m)
instance (ContM m) => ContM (ReaderT i m)
instance (ContM m) => ContM (IdT m)
instance (ExceptionM m j) => ExceptionM (ContT i m) j
instance (ExceptionM m j) => ExceptionM (StateT i m) j
instance (ExceptionM m j, Monoid i) => ExceptionM (WriterT i m) j
instance (ExceptionM m j) => ExceptionM (ReaderT i m) j
instance (ExceptionM m j) => ExceptionM (IdT m) j
instance (Monad m) => ExceptionM (ExceptionT i m) i
instance (StateM m j) => StateM (ContT i m) j
instance (StateM m j) => StateM (ExceptionT i m) j
instance (StateM m j, Monoid i) => StateM (WriterT i m) j
instance (StateM m j) => StateM (ReaderT i m) j
instance (StateM m j) => StateM (IdT m) j
instance (Monad m) => StateM (StateT i m) i
instance (WriterM m j) => WriterM (ContT i m) j
instance (WriterM m j) => WriterM (ExceptionT i m) j
instance (WriterM m j) => WriterM (StateT i m) j
instance (WriterM m j) => WriterM (ReaderT i m) j
instance (WriterM m j) => WriterM (IdT m) j
instance (Monad m, Monoid i) => WriterM (WriterT i m) i
instance (ReaderM m j) => ReaderM (ContT i m) j
instance (ReaderM m j) => ReaderM (ExceptionT i m) j
instance (ReaderM m j) => ReaderM (StateT i m) j
instance (ReaderM m j, Monoid i) => ReaderM (WriterT i m) j
instance (ReaderM m j) => ReaderM (IdT m) j
instance (Monad m) => ReaderM (ReaderT i m) i
instance (MonadPlus m) => MonadPlus (ExceptionT i m)
instance (MonadPlus m, Monoid i) => MonadPlus (WriterT i m)
instance (MonadPlus m) => MonadPlus (StateT i m)
instance (MonadPlus m) => MonadPlus (ReaderT i m)
instance (MonadPlus m) => MonadPlus (IdT m)
instance (MonadFix m) => MonadFix (ExceptionT i m)
instance (MonadFix m, Monoid i) => MonadFix (WriterT i m)
instance (MonadFix m) => MonadFix (StateT i m)
instance (MonadFix m) => MonadFix (ReaderT i m)
instance (MonadFix m) => MonadFix (IdT m)
instance MonadFix Lift
instance MonadFix Id
instance (Monad m) => Functor (ContT i m)
instance (Monad m) => Functor (ExceptionT i m)
instance (Monad m, Monoid i) => Functor (WriterT i m)
instance (Monad m) => Functor (StateT i m)
instance (Monad m) => Functor (ReaderT i m)
instance (Monad m) => Functor (IdT m)
instance Functor Lift
instance Functor Id
instance (Monad m) => Monad (ContT i m)
instance (Monad m) => Monad (ExceptionT i m)
instance (Monad m, Monoid i) => Monad (WriterT i m)
instance (Monad m) => Monad (StateT i m)
instance (Monad m) => Monad (ReaderT i m)
instance (Monad m) => Monad (IdT m)
instance Monad Lift
instance Monad Id
instance (BaseM m n) => BaseM (ContT i m) n
instance (BaseM m n) => BaseM (ExceptionT i m) n
instance (BaseM m n, Monoid i) => BaseM (WriterT i m) n
instance (BaseM m n) => BaseM (StateT i m) n
instance (BaseM m n) => BaseM (ReaderT i m) n
instance (BaseM m n) => BaseM (IdT m) n
instance BaseM Lift Lift
instance BaseM Id Id
instance BaseM [] []
instance BaseM Maybe Maybe
instance BaseM IO IO
instance MonadT (ContT i)
instance MonadT (ExceptionT i)
instance (Monoid i) => MonadT (WriterT i)
instance MonadT (StateT i)
instance MonadT (ReaderT i)
instance MonadT IdT
-- | This module contains a collection of monads that are defined in terms
-- of the monad transformers from MonadLib. The definitions in
-- this module are completely mechanical and so this module may become
-- obsolete if support for automated derivations for instances becomes
-- well supported across implementations.
module Monads
data Reader i a
data Writer i a
data State i a
data Exception i a
data Cont i a
runReader :: i -> Reader i a -> a
runWriter :: Writer i a -> (a, i)
runState :: i -> State i a -> (a, i)
runException :: Exception i a -> Either i a
runCont :: (a -> i) -> Cont i a -> i
instance RunExceptionM (Exception i) i
instance (Monoid i) => RunWriterM (Writer i) i
instance RunReaderM (Reader i) i
instance ContM (Cont i)
instance ExceptionM (Exception i) i
instance StateM (State i) i
instance (Monoid i) => WriterM (Writer i) i
instance ReaderM (Reader i) i
instance MonadFix (Exception i)
instance MonadFix (State i)
instance (Monoid i) => MonadFix (Writer i)
instance MonadFix (Reader i)
instance Functor (Cont i)
instance Functor (Exception i)
instance Functor (State i)
instance (Monoid i) => Functor (Writer i)
instance Functor (Reader i)
instance Monad (Cont i)
instance Monad (Exception i)
instance Monad (State i)
instance (Monoid i) => Monad (Writer i)
instance Monad (Reader i)
instance BaseM (Cont i) (Cont i)
instance BaseM (Exception i) (Exception i)
instance BaseM (State i) (State i)
instance (Monoid i) => BaseM (Writer i) (Writer i)
instance BaseM (Reader i) (Reader i)