-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/
-- | Concrete functor and monad transformers
--
-- A portable library of functor and monad transformers, inspired by the
-- paper "Functional Programming with Overloading and Higher-Order
-- Polymorphism", by Mark P Jones, in Advanced School of Functional
-- Programming, 1995
-- (http://web.cecs.pdx.edu/~mpj/pubs/springschool.html).
--
-- This package contains:
--
--
-- - the monad transformer class (in Control.Monad.Trans.Class)
-- and IO monad class (in Control.Monad.IO.Class)
-- - concrete functor and monad transformers, each with associated
-- operations and functions to lift operations associated with other
-- transformers.
--
--
-- The package can be used on its own in portable Haskell code, in which
-- case operations need to be manually lifted through transformer stacks
-- (see Control.Monad.Trans.Class for some examples).
-- Alternatively, it can be used with the non-portable monad classes in
-- the mtl or monads-tf packages, which automatically
-- lift operations introduced by monad transformers through other
-- transformers.
@package transformers
@version 0.4.0.0
-- | The class of monad transformers.
--
-- A monad transformer makes a new monad out of an existing monad, such
-- that computations of the old monad may be embedded in the new one. To
-- construct a monad with a desired set of features, one typically starts
-- with a base monad, such as Identity, [] or IO,
-- and applies a sequence of monad transformers.
module Control.Monad.Trans.Class
-- | The class of monad transformers. Instances should satisfy the
-- following laws, which state that lift is a monad
-- transformation:
--
--
class MonadTrans t
lift :: (MonadTrans t, Monad m) => m a -> t m a
-- | Signatures for monad operations that require specialized lifting.
module Control.Monad.Signatures
-- | Signature of the callCC operation, introduced in
-- Control.Monad.Trans.Cont.
type CallCC m a b = ((a -> m b) -> m a) -> m a
-- | Signature of the catchE operation, introduced in
-- Control.Monad.Trans.Except.
type Catch e m a = m a -> (e -> m a) -> m a
-- | Signature of the listen operation, introduced in
-- Control.Monad.Trans.Writer.
type Listen w m a = m a -> m (a, w)
-- | Signature of the pass operation, introduced in
-- Control.Monad.Trans.Writer.
type Pass w m a = m (a, w -> w) -> m a
-- | Class of monads based on IO.
module Control.Monad.IO.Class
-- | Monads in which IO computations may be embedded. Any monad
-- built by applying a sequence of monad transformers to the IO
-- monad will be an instance of this class.
--
-- Instances should satisfy the following laws, which state that
-- liftIO is a transformer of monads:
--
--
class Monad m => MonadIO m
liftIO :: MonadIO m => IO a -> m a
instance MonadIO IO
-- | Prelude classes, lifted to unary type constructors.
module Data.Functor.Classes
-- | Lifting of the Eq class to unary type constructors.
class Eq1 f
eq1 :: (Eq1 f, Eq a) => f a -> f a -> Bool
-- | Lifting of the Ord class to unary type constructors.
class Eq1 f => Ord1 f
compare1 :: (Ord1 f, Ord a) => f a -> f a -> Ordering
-- | Lifting of the Read class to unary type constructors.
class Read1 f
readsPrec1 :: (Read1 f, Read a) => Int -> ReadS (f a)
-- | Lifting of the Show class to unary type constructors.
class Show1 f
showsPrec1 :: (Show1 f, Show a) => Int -> f a -> ShowS
-- | readsData p d is a parser for datatypes where each
-- alternative begins with a data constructor. It parses the constructor
-- and passes it to p. Parsers for various constructors can be
-- constructed with readsUnary, readsUnary1 and
-- readsBinary1, and combined with mappend from the
-- Monoid class.
readsData :: (String -> ReadS a) -> Int -> ReadS a
-- | readsUnary n c n' matches the name of a unary data
-- constructor and then parses its argument using readsPrec.
readsUnary :: Read a => String -> (a -> t) -> String -> ReadS t
-- | readsUnary1 n c n' matches the name of a unary data
-- constructor and then parses its argument using readsPrec1.
readsUnary1 :: (Read1 f, Read a) => String -> (f a -> t) -> String -> ReadS t
-- | readsBinary1 n c n' matches the name of a binary data
-- constructor and then parses its arguments using readsPrec1.
readsBinary1 :: (Read1 f, Read1 g, Read a) => String -> (f a -> g a -> t) -> String -> ReadS t
-- | showsUnary n d x produces the string representation of
-- a unary data constructor with name n and argument x,
-- in precedence context d.
showsUnary :: Show a => String -> Int -> a -> ShowS
-- | showsUnary1 n d x produces the string representation
-- of a unary data constructor with name n and argument
-- x, in precedence context d.
showsUnary1 :: (Show1 f, Show a) => String -> Int -> f a -> ShowS
-- | showsBinary1 n d x produces the string representation
-- of a binary data constructor with name n and arguments
-- x and y, in precedence context d.
showsBinary1 :: (Show1 f, Show1 g, Show a) => String -> Int -> f a -> g a -> ShowS
instance Show a => Show1 (Either a)
instance Read a => Read1 (Either a)
instance Ord a => Ord1 (Either a)
instance Eq a => Eq1 (Either a)
instance Show a => Show1 ((,) a)
instance Read a => Read1 ((,) a)
instance Ord a => Ord1 ((,) a)
instance Eq a => Eq1 ((,) a)
instance Show1 []
instance Read1 []
instance Ord1 []
instance Eq1 []
instance Show1 Maybe
instance Read1 Maybe
instance Ord1 Maybe
instance Eq1 Maybe
-- | The constant functor.
module Data.Functor.Constant
-- | Constant functor.
newtype Constant a b
Constant :: a -> Constant a b
-- | Inverse of Constant.
getConstant :: Constant a b -> a
instance Eq a => Eq (Constant a b)
instance Ord a => Ord (Constant a b)
instance Read a => Read (Constant a b)
instance Show a => Show (Constant a b)
instance Monoid a => Applicative (Constant a)
instance Traversable (Constant a)
instance Foldable (Constant a)
instance Functor (Constant a)
instance Show a => Show1 (Constant a)
instance Read a => Read1 (Constant a)
instance Ord a => Ord1 (Constant a)
instance Eq a => Eq1 (Constant a)
-- | Adding a new kind of pure computation to an applicative functor.
module Control.Applicative.Lift
-- | Applicative functor formed by adding pure computations to a given
-- applicative functor.
data Lift f a
Pure :: a -> Lift f a
Other :: (f a) -> Lift f a
-- | Projection to the other functor.
unLift :: Applicative f => Lift f a -> f a
-- | An applicative functor that collects a monoid (e.g. lists) of errors.
-- A sequence of computations fails if any of its components do, but
-- unlike monads made with ExceptT from
-- Control.Monad.Trans.Except, these computations continue after
-- an error, collecting all the errors.
type Errors e = Lift (Constant e)
-- | Report an error.
failure :: Monoid e => e -> Errors e a
instance Alternative f => Alternative (Lift f)
instance Applicative f => Applicative (Lift f)
instance Traversable f => Traversable (Lift f)
instance Foldable f => Foldable (Lift f)
instance Functor f => Functor (Lift f)
instance Show1 f => Show1 (Lift f)
instance Read1 f => Read1 (Lift f)
instance Ord1 f => Ord1 (Lift f)
instance Eq1 f => Eq1 (Lift f)
instance (Show1 f, Show a) => Show (Lift f a)
instance (Read1 f, Read a) => Read (Lift f a)
instance (Ord1 f, Ord a) => Ord (Lift f a)
instance (Eq1 f, Eq a) => Eq (Lift f a)
-- | The identity functor and monad.
--
-- This trivial type constructor serves two purposes:
--
--
-- - It can be used with functions parameterized by functor or monad
-- classes.
-- - It can be used as a base monad to which a series of monad
-- transformers may be applied to construct a composite monad. Most monad
-- transformer modules include the special case of applying the
-- transformer to Identity. For example, State s is an
-- abbreviation for StateT s Identity.
--
module Data.Functor.Identity
-- | Identity functor and monad. (a non-strict monad)
newtype Identity a
Identity :: a -> Identity a
-- | Inverse of Identity.
runIdentity :: Identity a -> a
instance Eq a => Eq (Identity a)
instance Ord a => Ord (Identity a)
instance Read a => Read (Identity a)
instance Show a => Show (Identity a)
instance MonadFix Identity
instance Monad Identity
instance Applicative Identity
instance Traversable Identity
instance Foldable Identity
instance Functor Identity
instance Show1 Identity
instance Read1 Identity
instance Ord1 Identity
instance Eq1 Identity
-- | Continuation monads.
--
-- Delimited continuation operators are taken from Kenichi Asai and Oleg
-- Kiselyov's tutorial at CW 2011, "Introduction to programming with
-- shift and reset"
-- (http://okmij.org/ftp/continuations/#tutorial).
module Control.Monad.Trans.Cont
-- | Continuation monad. Cont r a is a CPS computation that
-- produces an intermediate result of type a within a CPS
-- computation whose final result type is r.
--
-- The return function simply creates a continuation which
-- passes the value on.
--
-- The >>= operator adds the bound function into the
-- continuation chain.
type Cont r = ContT r Identity
-- | Construct a continuation-passing computation from a function. (The
-- inverse of runCont)
cont :: ((a -> r) -> r) -> Cont r a
-- | The result of running a CPS computation with a given final
-- continuation. (The inverse of cont)
runCont :: Cont r a -> (a -> r) -> r
-- | The result of running a CPS computation with the identity as the final
-- continuation.
--
--
evalCont :: Cont r r -> r
-- | Apply a function to transform the result of a continuation-passing
-- computation.
--
--
mapCont :: (r -> r) -> Cont r a -> Cont r a
-- | Apply a function to transform the continuation passed to a CPS
-- computation.
--
--
withCont :: ((b -> r) -> (a -> r)) -> Cont r a -> Cont r b
-- | reset m delimits the continuation of any shift
-- inside m.
--
--
reset :: Cont r r -> Cont r' r
-- | shift f captures the continuation up to the nearest
-- enclosing reset and passes it to f:
--
--
shift :: ((a -> r) -> Cont r r) -> Cont r a
-- | The continuation monad transformer. Can be used to add continuation
-- handling to other monads.
newtype ContT r m a
ContT :: ((a -> m r) -> m r) -> ContT r m a
-- | The result of running a CPS computation with a given final
-- continuation. (The inverse of cont)
runContT :: ContT r m a -> (a -> m r) -> m r
-- | The result of running a CPS computation with return as the
-- final continuation.
--
--
evalContT :: Monad m => ContT r m r -> m r
-- | Apply a function to transform the result of a continuation-passing
-- computation.
--
--
mapContT :: (m r -> m r) -> ContT r m a -> ContT r m a
-- | Apply a function to transform the continuation passed to a CPS
-- computation.
--
--
withContT :: ((b -> m r) -> (a -> m r)) -> ContT r m a -> ContT r m b
-- | callCC (call-with-current-continuation) calls its argument
-- function, passing it the current continuation. It provides an escape
-- continuation mechanism for use with continuation monads. Escape
-- continuations one allow to abort the current computation and return a
-- value immediately. They achieve a similar effect to throwE and
-- catchE within an ExceptT monad. The advantage of this
-- function over calling return is that it makes the continuation
-- explicit, allowing more flexibility and better control.
--
-- The standard idiom used with callCC is to provide a
-- lambda-expression to name the continuation. Then calling the named
-- continuation anywhere within its scope will escape from the
-- computation, even if it is many layers deep within nested
-- computations.
callCC :: ((a -> ContT r m b) -> ContT r m a) -> ContT r m a
-- | resetT m delimits the continuation of any
-- shiftT inside m.
--
--
resetT :: Monad m => ContT r m r -> ContT r' m r
-- | shiftT f captures the continuation up to the nearest
-- enclosing resetT and passes it to f:
--
--
shiftT :: Monad m => ((a -> m r) -> ContT r m r) -> ContT r m a
-- | liftLocal ask local yields a local function
-- for ContT r m.
liftLocal :: Monad m => m r' -> ((r' -> r') -> m r -> m r) -> (r' -> r') -> ContT r m a -> ContT r m a
instance MonadIO m => MonadIO (ContT r m)
instance MonadTrans (ContT r)
instance Monad (ContT r m)
instance Applicative (ContT r m)
instance Functor (ContT r m)
-- | Declaration of the ReaderT monad transformer, which adds a
-- static environment to a given monad.
--
-- If the computation is to modify the stored information, use
-- Control.Monad.Trans.State instead.
module Control.Monad.Trans.Reader
-- | The parameterizable reader monad.
--
-- Computations are functions of a shared environment.
--
-- The return function ignores the environment, while
-- >>= passes the inherited environment to both
-- subcomputations.
type Reader r = ReaderT r Identity
-- | Constructor for computations in the reader monad (equivalent to
-- asks).
reader :: Monad m => (r -> a) -> ReaderT r m a
-- | Runs a Reader and extracts the final value from it. (The
-- inverse of reader.)
runReader :: Reader r a -> r -> a
-- | Transform the value returned by a Reader.
--
--
mapReader :: (a -> b) -> Reader r a -> Reader r b
-- | Execute a computation in a modified environment (a specialization of
-- withReaderT).
--
--
withReader :: (r' -> r) -> Reader r a -> Reader r' a
-- | The reader monad transformer, which adds a read-only environment to
-- the given monad.
--
-- The return function ignores the environment, while
-- >>= passes the inherited environment to both
-- subcomputations.
newtype ReaderT r m a
ReaderT :: (r -> m a) -> ReaderT r m a
-- | The underlying computation, as a function of the environment. (inverse
-- of ReaderT)
runReaderT :: ReaderT r m a -> r -> m a
-- | Transform the computation inside a ReaderT.
--
--
mapReaderT :: (m a -> n b) -> ReaderT r m a -> ReaderT r n b
-- | Execute a computation in a modified environment (a more general
-- version of local).
--
--
withReaderT :: (r' -> r) -> ReaderT r m a -> ReaderT r' m a
-- | Fetch the value of the environment.
ask :: Monad m => ReaderT r m r
-- | Execute a computation in a modified environment (a specialization of
-- withReaderT).
--
--
local :: Monad m => (r -> r) -> ReaderT r m a -> ReaderT r m a
-- | Retrieve a function of the current environment.
--
--
asks :: Monad m => (r -> a) -> ReaderT r m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m a b -> CallCC (ReaderT r m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m a -> Catch e (ReaderT r m) a
instance MonadIO m => MonadIO (ReaderT r m)
instance MonadTrans (ReaderT r)
instance MonadFix m => MonadFix (ReaderT r m)
instance MonadPlus m => MonadPlus (ReaderT r m)
instance Monad m => Monad (ReaderT r m)
instance Alternative m => Alternative (ReaderT r m)
instance Applicative m => Applicative (ReaderT r m)
instance Functor m => Functor (ReaderT r m)
-- | A monad transformer that combines ReaderT, WriterT
-- and StateT. This version is lazy; for a strict version with
-- the same interface, see Control.Monad.Trans.RWS.Strict.
module Control.Monad.Trans.RWS.Lazy
-- | A monad containing an environment of type r, output of type
-- w and an updatable state of type s.
type RWS r w s = RWST r w s Identity
-- | Construct an RWS computation from a function. (The inverse of
-- runRWS.)
rws :: (r -> s -> (a, s, w)) -> RWS r w s a
-- | Unwrap an RWS computation as a function. (The inverse of rws.)
runRWS :: RWS r w s a -> r -> s -> (a, s, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final value and output, discarding the final state.
evalRWS :: RWS r w s a -> r -> s -> (a, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final state and output, discarding the final value.
execRWS :: RWS r w s a -> r -> s -> (s, w)
-- | Map the return value, final state and output of a computation using
-- the given function.
--
--
mapRWS :: ((a, s, w) -> (b, s, w')) -> RWS r w s a -> RWS r w' s b
-- | withRWS f m executes action m with an initial
-- environment and state modified by applying f.
--
--
withRWS :: (r' -> s -> (r, s)) -> RWS r w s a -> RWS r' w s a
-- | A monad transformer adding reading an environment of type r,
-- collecting an output of type w and updating a state of type
-- s to an inner monad m.
newtype RWST r w s m a
RWST :: (r -> s -> m (a, s, w)) -> RWST r w s m a
-- | The inverse of RWST.
runRWST :: RWST r w s m a -> r -> s -> m (a, s, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final value and output, discarding the final state.
evalRWST :: Monad m => RWST r w s m a -> r -> s -> m (a, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final state and output, discarding the final value.
execRWST :: Monad m => RWST r w s m a -> r -> s -> m (s, w)
-- | Map the inner computation using the given function.
--
--
mapRWST :: (m (a, s, w) -> n (b, s, w')) -> RWST r w s m a -> RWST r w' s n b
-- | withRWST f m executes action m with an
-- initial environment and state modified by applying f.
--
--
withRWST :: (r' -> s -> (r, s)) -> RWST r w s m a -> RWST r' w s m a
-- | Constructor for computations in the reader monad (equivalent to
-- asks).
reader :: (Monoid w, Monad m) => (r -> a) -> RWST r w s m a
-- | Fetch the value of the environment.
ask :: (Monoid w, Monad m) => RWST r w s m r
-- | Execute a computation in a modified environment
--
--
local :: (Monoid w, Monad m) => (r -> r) -> RWST r w s m a -> RWST r w s m a
-- | Retrieve a function of the current environment.
--
--
asks :: (Monoid w, Monad m) => (r -> a) -> RWST r w s m a
-- | Construct a writer computation from a (result, output) pair.
writer :: Monad m => (a, w) -> RWST r w s m a
-- | tell w is an action that produces the output
-- w.
tell :: (Monoid w, Monad m) => w -> RWST r w s m ()
-- | listen m is an action that executes the action
-- m and adds its output to the value of the computation.
--
--
listen :: (Monoid w, Monad m) => RWST r w s m a -> RWST r w s m (a, w)
-- | listens f m is an action that executes the action
-- m and adds the result of applying f to the output to
-- the value of the computation.
--
--
listens :: (Monoid w, Monad m) => (w -> b) -> RWST r w s m a -> RWST r w s m (a, b)
-- | pass m is an action that executes the action
-- m, which returns a value and a function, and returns the
-- value, applying the function to the output.
--
--
pass :: (Monoid w, Monad m) => RWST r w s m (a, w -> w) -> RWST r w s m a
-- | censor f m is an action that executes the action
-- m and applies the function f to its output, leaving
-- the return value unchanged.
--
--
censor :: (Monoid w, Monad m) => (w -> w) -> RWST r w s m a -> RWST r w s m a
-- | Construct a state monad computation from a state transformer function.
state :: (Monoid w, Monad m) => (s -> (a, s)) -> RWST r w s m a
-- | Fetch the current value of the state within the monad.
get :: (Monoid w, Monad m) => RWST r w s m s
-- | put s sets the state within the monad to s.
put :: (Monoid w, Monad m) => s -> RWST r w s m ()
-- | modify f is an action that updates the state to the
-- result of applying f to the current state.
--
--
modify :: (Monoid w, Monad m) => (s -> s) -> RWST r w s m ()
-- | Get a specific component of the state, using a projection function
-- supplied.
--
--
gets :: (Monoid w, Monad m) => (s -> a) -> RWST r w s m a
-- | Uniform lifting of a callCC operation to the new monad. This
-- version rolls back to the original state on entering the continuation.
liftCallCC :: Monoid w => CallCC m (a, s, w) (b, s, w) -> CallCC (RWST r w s m) a b
-- | In-situ lifting of a callCC operation to the new monad. This
-- version uses the current state on entering the continuation.
liftCallCC' :: Monoid w => CallCC m (a, s, w) (b, s, w) -> CallCC (RWST r w s m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, s, w) -> Catch e (RWST r w s m) a
instance (Monoid w, MonadIO m) => MonadIO (RWST r w s m)
instance Monoid w => MonadTrans (RWST r w s)
instance (Monoid w, MonadFix m) => MonadFix (RWST r w s m)
instance (Monoid w, MonadPlus m) => MonadPlus (RWST r w s m)
instance (Monoid w, Monad m) => Monad (RWST r w s m)
instance (Monoid w, Functor m, MonadPlus m) => Alternative (RWST r w s m)
instance (Monoid w, Functor m, Monad m) => Applicative (RWST r w s m)
instance Functor m => Functor (RWST r w s m)
-- | A monad transformer that combines ReaderT, WriterT
-- and StateT. This version is lazy; for a strict version, see
-- Control.Monad.Trans.RWS.Strict, which has the same interface.
module Control.Monad.Trans.RWS
-- | A monad transformer that combines ReaderT, WriterT
-- and StateT. This version is strict; for a lazy version with
-- the same interface, see Control.Monad.Trans.RWS.Lazy.
module Control.Monad.Trans.RWS.Strict
-- | A monad containing an environment of type r, output of type
-- w and an updatable state of type s.
type RWS r w s = RWST r w s Identity
-- | Construct an RWS computation from a function. (The inverse of
-- runRWS.)
rws :: (r -> s -> (a, s, w)) -> RWS r w s a
-- | Unwrap an RWS computation as a function. (The inverse of rws.)
runRWS :: RWS r w s a -> r -> s -> (a, s, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final value and output, discarding the final state.
evalRWS :: RWS r w s a -> r -> s -> (a, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final state and output, discarding the final value.
execRWS :: RWS r w s a -> r -> s -> (s, w)
-- | Map the return value, final state and output of a computation using
-- the given function.
--
--
mapRWS :: ((a, s, w) -> (b, s, w')) -> RWS r w s a -> RWS r w' s b
-- | withRWS f m executes action m with an initial
-- environment and state modified by applying f.
--
--
withRWS :: (r' -> s -> (r, s)) -> RWS r w s a -> RWS r' w s a
-- | A monad transformer adding reading an environment of type r,
-- collecting an output of type w and updating a state of type
-- s to an inner monad m.
newtype RWST r w s m a
RWST :: (r -> s -> m (a, s, w)) -> RWST r w s m a
-- | The inverse of RWST.
runRWST :: RWST r w s m a -> r -> s -> m (a, s, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final value and output, discarding the final state.
evalRWST :: Monad m => RWST r w s m a -> r -> s -> m (a, w)
-- | Evaluate a computation with the given initial state and environment,
-- returning the final state and output, discarding the final value.
execRWST :: Monad m => RWST r w s m a -> r -> s -> m (s, w)
-- | Map the inner computation using the given function.
--
--
mapRWST :: (m (a, s, w) -> n (b, s, w')) -> RWST r w s m a -> RWST r w' s n b
-- | withRWST f m executes action m with an
-- initial environment and state modified by applying f.
--
--
withRWST :: (r' -> s -> (r, s)) -> RWST r w s m a -> RWST r' w s m a
-- | Constructor for computations in the reader monad (equivalent to
-- asks).
reader :: (Monoid w, Monad m) => (r -> a) -> RWST r w s m a
-- | Fetch the value of the environment.
ask :: (Monoid w, Monad m) => RWST r w s m r
-- | Execute a computation in a modified environment
--
--
local :: (Monoid w, Monad m) => (r -> r) -> RWST r w s m a -> RWST r w s m a
-- | Retrieve a function of the current environment.
--
--
asks :: (Monoid w, Monad m) => (r -> a) -> RWST r w s m a
-- | Construct a writer computation from a (result, output) pair.
writer :: Monad m => (a, w) -> RWST r w s m a
-- | tell w is an action that produces the output
-- w.
tell :: (Monoid w, Monad m) => w -> RWST r w s m ()
-- | listen m is an action that executes the action
-- m and adds its output to the value of the computation.
--
--
listen :: (Monoid w, Monad m) => RWST r w s m a -> RWST r w s m (a, w)
-- | listens f m is an action that executes the action
-- m and adds the result of applying f to the output to
-- the value of the computation.
--
--
listens :: (Monoid w, Monad m) => (w -> b) -> RWST r w s m a -> RWST r w s m (a, b)
-- | pass m is an action that executes the action
-- m, which returns a value and a function, and returns the
-- value, applying the function to the output.
--
--
pass :: (Monoid w, Monad m) => RWST r w s m (a, w -> w) -> RWST r w s m a
-- | censor f m is an action that executes the action
-- m and applies the function f to its output, leaving
-- the return value unchanged.
--
--
censor :: (Monoid w, Monad m) => (w -> w) -> RWST r w s m a -> RWST r w s m a
-- | Construct a state monad computation from a state transformer function.
state :: (Monoid w, Monad m) => (s -> (a, s)) -> RWST r w s m a
-- | Fetch the current value of the state within the monad.
get :: (Monoid w, Monad m) => RWST r w s m s
-- | put s sets the state within the monad to s.
put :: (Monoid w, Monad m) => s -> RWST r w s m ()
-- | modify f is an action that updates the state to the
-- result of applying f to the current state.
--
--
modify :: (Monoid w, Monad m) => (s -> s) -> RWST r w s m ()
-- | Get a specific component of the state, using a projection function
-- supplied.
--
--
gets :: (Monoid w, Monad m) => (s -> a) -> RWST r w s m a
-- | Uniform lifting of a callCC operation to the new monad. This
-- version rolls back to the original state on entering the continuation.
liftCallCC :: Monoid w => CallCC m (a, s, w) (b, s, w) -> CallCC (RWST r w s m) a b
-- | In-situ lifting of a callCC operation to the new monad. This
-- version uses the current state on entering the continuation.
liftCallCC' :: Monoid w => CallCC m (a, s, w) (b, s, w) -> CallCC (RWST r w s m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, s, w) -> Catch e (RWST r w s m) a
instance (Monoid w, MonadIO m) => MonadIO (RWST r w s m)
instance Monoid w => MonadTrans (RWST r w s)
instance (Monoid w, MonadFix m) => MonadFix (RWST r w s m)
instance (Monoid w, MonadPlus m) => MonadPlus (RWST r w s m)
instance (Monoid w, Monad m) => Monad (RWST r w s m)
instance (Monoid w, Functor m, MonadPlus m) => Alternative (RWST r w s m)
instance (Monoid w, Functor m, Monad m) => Applicative (RWST r w s m)
instance Functor m => Functor (RWST r w s m)
-- | Lazy state monads, passing an updatable state through a computation.
-- See below for examples.
--
-- Some computations may not require the full power of state
-- transformers:
--
--
--
-- In this version, sequencing of computations is lazy, so that for
-- example the following produces a usable result:
--
--
-- evalState (sequence $ repeat $ do { n <- get; put (n*2); return n }) 1
--
--
-- For a strict version with the same interface, see
-- Control.Monad.Trans.State.Strict.
module Control.Monad.Trans.State.Lazy
-- | A state monad parameterized by the type s of the state to
-- carry.
--
-- The return function leaves the state unchanged, while
-- >>= uses the final state of the first computation as
-- the initial state of the second.
type State s = StateT s Identity
-- | Construct a state monad computation from a function. (The inverse of
-- runState.)
state :: Monad m => (s -> (a, s)) -> StateT s m a
-- | Unwrap a state monad computation as a function. (The inverse of
-- state.)
runState :: State s a -> s -> (a, s)
-- | Evaluate a state computation with the given initial state and return
-- the final value, discarding the final state.
--
--
evalState :: State s a -> s -> a
-- | Evaluate a state computation with the given initial state and return
-- the final state, discarding the final value.
--
--
execState :: State s a -> s -> s
-- | Map both the return value and final state of a computation using the
-- given function.
--
--
mapState :: ((a, s) -> (b, s)) -> State s a -> State s b
-- | withState f m executes action m on a state
-- modified by applying f.
--
--
withState :: (s -> s) -> State s a -> State s a
-- | A state transformer monad parameterized by:
--
--
-- - s - The state.
-- - m - The inner monad.
--
--
-- The return function leaves the state unchanged, while
-- >>= uses the final state of the first computation as
-- the initial state of the second.
newtype StateT s m a
StateT :: (s -> m (a, s)) -> StateT s m a
-- | Evaluate a state computation with the given initial state and return
-- the final value and state. (inverse of StateT)
runStateT :: StateT s m a -> s -> m (a, s)
-- | Evaluate a state computation with the given initial state and return
-- the final value, discarding the final state.
--
--
evalStateT :: Monad m => StateT s m a -> s -> m a
-- | Evaluate a state computation with the given initial state and return
-- the final state, discarding the final value.
--
--
execStateT :: Monad m => StateT s m a -> s -> m s
-- | Map both the return value and final state of a computation using the
-- given function.
--
--
mapStateT :: (m (a, s) -> n (b, s)) -> StateT s m a -> StateT s n b
-- | withStateT f m executes action m on a state
-- modified by applying f.
--
--
withStateT :: (s -> s) -> StateT s m a -> StateT s m a
-- | Fetch the current value of the state within the monad.
get :: Monad m => StateT s m s
-- | put s sets the state within the monad to s.
put :: Monad m => s -> StateT s m ()
-- | modify f is an action that updates the state to the
-- result of applying f to the current state.
--
--
modify :: Monad m => (s -> s) -> StateT s m ()
-- | A variant of modify in which the computation is strict in the
-- new state.
--
--
modify' :: Monad m => (s -> s) -> StateT s m ()
-- | Get a specific component of the state, using a projection function
-- supplied.
--
--
gets :: Monad m => (s -> a) -> StateT s m a
-- | Uniform lifting of a callCC operation to the new monad. This
-- version rolls back to the original state on entering the continuation.
liftCallCC :: CallCC m (a, s) (b, s) -> CallCC (StateT s m) a b
-- | In-situ lifting of a callCC operation to the new monad. This
-- version uses the current state on entering the continuation. It does
-- not satisfy the laws of a monad transformer.
liftCallCC' :: CallCC m (a, s) (b, s) -> CallCC (StateT s m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, s) -> Catch e (StateT s m) a
-- | Lift a listen operation to the new monad.
liftListen :: Monad m => Listen w m (a, s) -> Listen w (StateT s m) a
-- | Lift a pass operation to the new monad.
liftPass :: Monad m => Pass w m (a, s) -> Pass w (StateT s m) a
instance MonadIO m => MonadIO (StateT s m)
instance MonadTrans (StateT s)
instance MonadFix m => MonadFix (StateT s m)
instance MonadPlus m => MonadPlus (StateT s m)
instance Monad m => Monad (StateT s m)
instance (Functor m, MonadPlus m) => Alternative (StateT s m)
instance (Functor m, Monad m) => Applicative (StateT s m)
instance Functor m => Functor (StateT s m)
-- | State monads, passing an updatable state through a computation.
--
-- Some computations may not require the full power of state
-- transformers:
--
--
--
-- This version is lazy; for a strict version, see
-- Control.Monad.Trans.State.Strict, which has the same interface.
module Control.Monad.Trans.State
-- | Strict state monads, passing an updatable state through a computation.
-- See below for examples.
--
-- Some computations may not require the full power of state
-- transformers:
--
--
--
-- In this version, sequencing of computations is strict (but
-- computations are not strict in the state unless you force it with
-- seq or the like). For a lazy version with the same interface,
-- see Control.Monad.Trans.State.Lazy.
module Control.Monad.Trans.State.Strict
-- | A state monad parameterized by the type s of the state to
-- carry.
--
-- The return function leaves the state unchanged, while
-- >>= uses the final state of the first computation as
-- the initial state of the second.
type State s = StateT s Identity
-- | Construct a state monad computation from a function. (The inverse of
-- runState.)
state :: Monad m => (s -> (a, s)) -> StateT s m a
-- | Unwrap a state monad computation as a function. (The inverse of
-- state.)
runState :: State s a -> s -> (a, s)
-- | Evaluate a state computation with the given initial state and return
-- the final value, discarding the final state.
--
--
evalState :: State s a -> s -> a
-- | Evaluate a state computation with the given initial state and return
-- the final state, discarding the final value.
--
--
execState :: State s a -> s -> s
-- | Map both the return value and final state of a computation using the
-- given function.
--
--
mapState :: ((a, s) -> (b, s)) -> State s a -> State s b
-- | withState f m executes action m on a state
-- modified by applying f.
--
--
withState :: (s -> s) -> State s a -> State s a
-- | A state transformer monad parameterized by:
--
--
-- - s - The state.
-- - m - The inner monad.
--
--
-- The return function leaves the state unchanged, while
-- >>= uses the final state of the first computation as
-- the initial state of the second.
newtype StateT s m a
StateT :: (s -> m (a, s)) -> StateT s m a
-- | Evaluate a state computation with the given initial state and return
-- the final value and state. (inverse of StateT)
runStateT :: StateT s m a -> s -> m (a, s)
-- | Evaluate a state computation with the given initial state and return
-- the final value, discarding the final state.
--
--
evalStateT :: Monad m => StateT s m a -> s -> m a
-- | Evaluate a state computation with the given initial state and return
-- the final state, discarding the final value.
--
--
execStateT :: Monad m => StateT s m a -> s -> m s
-- | Map both the return value and final state of a computation using the
-- given function.
--
--
mapStateT :: (m (a, s) -> n (b, s)) -> StateT s m a -> StateT s n b
-- | withStateT f m executes action m on a state
-- modified by applying f.
--
--
withStateT :: (s -> s) -> StateT s m a -> StateT s m a
-- | Fetch the current value of the state within the monad.
get :: Monad m => StateT s m s
-- | put s sets the state within the monad to s.
put :: Monad m => s -> StateT s m ()
-- | modify f is an action that updates the state to the
-- result of applying f to the current state.
--
--
modify :: Monad m => (s -> s) -> StateT s m ()
-- | A variant of modify in which the computation is strict in the
-- new state.
--
--
modify' :: Monad m => (s -> s) -> StateT s m ()
-- | Get a specific component of the state, using a projection function
-- supplied.
--
--
gets :: Monad m => (s -> a) -> StateT s m a
-- | Uniform lifting of a callCC operation to the new monad. This
-- version rolls back to the original state on entering the continuation.
liftCallCC :: CallCC m (a, s) (b, s) -> CallCC (StateT s m) a b
-- | In-situ lifting of a callCC operation to the new monad. This
-- version uses the current state on entering the continuation. It does
-- not satisfy the laws of a monad transformer.
liftCallCC' :: CallCC m (a, s) (b, s) -> CallCC (StateT s m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, s) -> Catch e (StateT s m) a
-- | Lift a listen operation to the new monad.
liftListen :: Monad m => Listen w m (a, s) -> Listen w (StateT s m) a
-- | Lift a pass operation to the new monad.
liftPass :: Monad m => Pass w m (a, s) -> Pass w (StateT s m) a
instance MonadIO m => MonadIO (StateT s m)
instance MonadTrans (StateT s)
instance MonadFix m => MonadFix (StateT s m)
instance MonadPlus m => MonadPlus (StateT s m)
instance Monad m => Monad (StateT s m)
instance (Functor m, MonadPlus m) => Alternative (StateT s m)
instance (Functor m, Monad m) => Applicative (StateT s m)
instance Functor m => Functor (StateT s m)
-- | This monad transformer extends a monad with the ability throw
-- exceptions.
--
-- A sequence of actions terminates normally, producing a value, only if
-- none of the actions in the sequence throws an exception. If one throws
-- an exception, the rest of the sequence is skipped and the composite
-- action exits with that exception.
--
-- If the value of the exception is not required, the variant in
-- Control.Monad.Trans.Maybe may be used instead.
module Control.Monad.Trans.Except
-- | The parameterizable exception monad.
--
-- Computations are either exceptions or normal values.
--
-- The return function returns a normal value, while
-- >>= exits on the first exception.
type Except e = ExceptT e Identity
-- | Constructor for computations in the exception monad. (The inverse of
-- runExcept).
except :: Either e a -> Except e a
-- | Extractor for computations in the exception monad. (The inverse of
-- except).
runExcept :: Except e a -> Either e a
-- | Map the unwrapped computation using the given function.
--
--
mapExcept :: (Either e a -> Either e' b) -> Except e a -> Except e' b
-- | Transform any exceptions thrown by the computation using the given
-- function (a specialization of withExceptT).
withExcept :: (e -> e') -> Except e a -> Except e' a
-- | A monad transformer that adds exceptions to other monads.
--
-- ExceptT constructs a monad parameterized over two things:
--
--
-- - e - The exception type.
-- - m - The inner monad.
--
--
-- The return function yields a computation that produces the
-- given value, while >>= sequences two subcomputations,
-- exiting on the first exception.
newtype ExceptT e m a
ExceptT :: (m (Either e a)) -> ExceptT e m a
-- | The inverse of ExceptT.
runExceptT :: ExceptT e m a -> m (Either e a)
-- | Map the unwrapped computation using the given function.
--
--
mapExceptT :: (m (Either e a) -> n (Either e' b)) -> ExceptT e m a -> ExceptT e' n b
-- | Transform any exceptions thrown by the computation using the given
-- function.
withExceptT :: Functor m => (e -> e') -> ExceptT e m a -> ExceptT e' m a
-- | Signal an exception value e.
--
--
throwE :: Monad m => e -> ExceptT e m a
-- | Handle an exception.
--
--
catchE :: Monad m => ExceptT e m a -> (e -> ExceptT e' m a) -> ExceptT e' m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m (Either e a) (Either e b) -> CallCC (ExceptT e m) a b
-- | Lift a listen operation to the new monad.
liftListen :: Monad m => Listen w m (Either e a) -> Listen w (ExceptT e m) a
-- | Lift a pass operation to the new monad.
liftPass :: Monad m => Pass w m (Either e a) -> Pass w (ExceptT e m) a
instance MonadIO m => MonadIO (ExceptT e m)
instance MonadTrans (ExceptT e)
instance MonadFix m => MonadFix (ExceptT e m)
instance (Monad m, Monoid e) => MonadPlus (ExceptT e m)
instance Monad m => Monad (ExceptT e m)
instance (Functor m, Monad m, Monoid e) => Alternative (ExceptT e m)
instance (Functor m, Monad m) => Applicative (ExceptT e m)
instance Traversable f => Traversable (ExceptT e f)
instance Foldable f => Foldable (ExceptT e f)
instance Functor m => Functor (ExceptT e m)
instance (Show e, Show1 m) => Show1 (ExceptT e m)
instance (Read e, Read1 m) => Read1 (ExceptT e m)
instance (Ord e, Ord1 m) => Ord1 (ExceptT e m)
instance (Eq e, Eq1 m) => Eq1 (ExceptT e m)
instance (Show e, Show1 m, Show a) => Show (ExceptT e m a)
instance (Read e, Read1 m, Read a) => Read (ExceptT e m a)
instance (Ord e, Ord1 m, Ord a) => Ord (ExceptT e m a)
instance (Eq e, Eq1 m, Eq a) => Eq (ExceptT e m a)
-- | This monad transformer adds the ability to fail or throw exceptions to
-- a monad.
--
-- A sequence of actions succeeds, producing a value, only if all the
-- actions in the sequence are successful. If one fails with an error,
-- the rest of the sequence is skipped and the composite action fails
-- with that error.
--
-- If the value of the error is not required, the variant in
-- Control.Monad.Trans.Maybe may be used instead.
--
-- Note: This module will be removed in a future release. Instead,
-- use Control.Monad.Trans.Except, which does not restrict the
-- exception type, and also includes a base exception monad.
-- | Deprecated: Use Control.Monad.Trans.Except instead
module Control.Monad.Trans.Error
-- | An exception to be thrown.
--
-- Minimal complete definition: noMsg or strMsg.
class Error a where noMsg = strMsg "" strMsg _ = noMsg
noMsg :: Error a => a
strMsg :: Error a => String -> a
-- | Workaround so that we can have a Haskell 98 instance Error
-- String.
class ErrorList a
listMsg :: ErrorList a => String -> [a]
-- | The error monad transformer. It can be used to add error handling to
-- other monads.
--
-- The ErrorT Monad structure is parameterized over two things:
--
--
-- - e - The error type.
-- - m - The inner monad.
--
--
-- The return function yields a successful computation, while
-- >>= sequences two subcomputations, failing on the first
-- error.
newtype ErrorT e m a
ErrorT :: (m (Either e a)) -> ErrorT e m a
-- | Inverse of ErrorT.
runErrorT :: ErrorT e m a -> m (Either e a)
-- | Map the unwrapped computation using the given function.
--
--
mapErrorT :: (m (Either e a) -> n (Either e' b)) -> ErrorT e m a -> ErrorT e' n b
-- | Signal an error value e.
--
--
throwError :: (Monad m, Error e) => e -> ErrorT e m a
-- | Handle an error.
--
--
catchError :: (Monad m, Error e) => ErrorT e m a -> (e -> ErrorT e m a) -> ErrorT e m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m (Either e a) (Either e b) -> CallCC (ErrorT e m) a b
-- | Lift a listen operation to the new monad.
liftListen :: Monad m => Listen w m (Either e a) -> Listen w (ErrorT e m) a
-- | Lift a pass operation to the new monad.
liftPass :: Monad m => Pass w m (Either e a) -> Pass w (ErrorT e m) a
instance (Error e, MonadIO m) => MonadIO (ErrorT e m)
instance Error e => MonadTrans (ErrorT e)
instance (MonadFix m, Error e) => MonadFix (ErrorT e m)
instance (Monad m, Error e) => MonadPlus (ErrorT e m)
instance (Monad m, Error e) => Monad (ErrorT e m)
instance (Functor m, Monad m, Error e) => Alternative (ErrorT e m)
instance (Functor m, Monad m) => Applicative (ErrorT e m)
instance Traversable f => Traversable (ErrorT e f)
instance Foldable f => Foldable (ErrorT e f)
instance Functor m => Functor (ErrorT e m)
instance (Show e, Show1 m) => Show1 (ErrorT e m)
instance (Read e, Read1 m) => Read1 (ErrorT e m)
instance (Ord e, Ord1 m) => Ord1 (ErrorT e m)
instance (Eq e, Eq1 m) => Eq1 (ErrorT e m)
instance (Show e, Show1 m, Show a) => Show (ErrorT e m a)
instance (Read e, Read1 m, Read a) => Read (ErrorT e m a)
instance (Ord e, Ord1 m, Ord a) => Ord (ErrorT e m a)
instance (Eq e, Eq1 m, Eq a) => Eq (ErrorT e m a)
instance Error e => MonadPlus (Either e)
instance Error e => Alternative (Either e)
instance ErrorList Char
instance ErrorList a => Error [a]
instance Error IOException
instance Alternative IO
instance MonadPlus IO
-- | The identity monad transformer.
--
-- This is useful for functions parameterized by a monad transformer.
module Control.Monad.Trans.Identity
-- | The trivial monad transformer, which maps a monad to an equivalent
-- monad.
newtype IdentityT f a
IdentityT :: (f a) -> IdentityT f a
-- | The inverse of IdentityT.
runIdentityT :: IdentityT f a -> f a
-- | Lift a unary operation to the new monad.
mapIdentityT :: (m a -> n b) -> IdentityT m a -> IdentityT n b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m a -> Catch e (IdentityT m) a
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m a b -> CallCC (IdentityT m) a b
instance MonadTrans IdentityT
instance MonadIO m => MonadIO (IdentityT m)
instance MonadFix m => MonadFix (IdentityT m)
instance MonadPlus m => MonadPlus (IdentityT m)
instance Monad m => Monad (IdentityT m)
instance Alternative m => Alternative (IdentityT m)
instance Applicative m => Applicative (IdentityT m)
instance Traversable f => Traversable (IdentityT f)
instance Foldable f => Foldable (IdentityT f)
instance Functor m => Functor (IdentityT m)
instance Show1 f => Show1 (IdentityT f)
instance Read1 f => Read1 (IdentityT f)
instance Ord1 f => Ord1 (IdentityT f)
instance Eq1 f => Eq1 (IdentityT f)
instance (Show1 f, Show a) => Show (IdentityT f a)
instance (Read1 f, Read a) => Read (IdentityT f a)
instance (Ord1 f, Ord a) => Ord (IdentityT f a)
instance (Eq1 f, Eq a) => Eq (IdentityT f a)
-- | The ListT monad transformer, adding backtracking to a given monad,
-- which must be commutative.
module Control.Monad.Trans.List
-- | Parameterizable list monad, with an inner monad.
--
-- Note: this does not yield a monad unless the argument monad is
-- commutative.
newtype ListT m a
ListT :: (m [a]) -> ListT m a
-- | The inverse of ListT.
runListT :: ListT m a -> m [a]
-- | Map between ListT computations.
--
--
mapListT :: (m [a] -> n [b]) -> ListT m a -> ListT n b
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m [a] [b] -> CallCC (ListT m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m [a] -> Catch e (ListT m) a
instance MonadIO m => MonadIO (ListT m)
instance MonadTrans ListT
instance Monad m => MonadPlus (ListT m)
instance Monad m => Monad (ListT m)
instance Applicative m => Alternative (ListT m)
instance Applicative m => Applicative (ListT m)
instance Traversable f => Traversable (ListT f)
instance Foldable f => Foldable (ListT f)
instance Functor m => Functor (ListT m)
instance Show1 m => Show1 (ListT m)
instance Read1 m => Read1 (ListT m)
instance Ord1 m => Ord1 (ListT m)
instance Eq1 m => Eq1 (ListT m)
instance (Show1 m, Show a) => Show (ListT m a)
instance (Read1 m, Read a) => Read (ListT m a)
instance (Ord1 m, Ord a) => Ord (ListT m a)
instance (Eq1 m, Eq a) => Eq (ListT m a)
-- | The MaybeT monad transformer extends a monad with the ability
-- to exit the computation without returning a value.
--
-- A sequence of actions produces a value only if all the actions in the
-- sequence do. If one exits, the rest of the sequence is skipped and the
-- composite action exits.
--
-- For a variant allowing a range of exception values, see
-- Control.Monad.Trans.Except.
module Control.Monad.Trans.Maybe
-- | The parameterizable maybe monad, obtained by composing an arbitrary
-- monad with the Maybe monad.
--
-- Computations are actions that may produce a value or exit.
--
-- The return function yields a computation that produces that
-- value, while >>= sequences two subcomputations, exiting
-- if either computation does.
newtype MaybeT m a
MaybeT :: (m (Maybe a)) -> MaybeT m a
-- | The inverse of MaybeT.
runMaybeT :: MaybeT m a -> m (Maybe a)
-- | Transform the computation inside a MaybeT.
--
--
mapMaybeT :: (m (Maybe a) -> n (Maybe b)) -> MaybeT m a -> MaybeT n b
-- | Convert a MaybeT computation to ExceptT, with a default
-- exception value.
maybeToExceptT :: Functor m => e -> MaybeT m a -> ExceptT e m a
-- | Convert a ExceptT computation to MaybeT, discarding the
-- value of any exception.
exceptToMaybeT :: Functor m => ExceptT e m a -> MaybeT m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: CallCC m (Maybe a) (Maybe b) -> CallCC (MaybeT m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (Maybe a) -> Catch e (MaybeT m) a
-- | Lift a listen operation to the new monad.
liftListen :: Monad m => Listen w m (Maybe a) -> Listen w (MaybeT m) a
-- | Lift a pass operation to the new monad.
liftPass :: Monad m => Pass w m (Maybe a) -> Pass w (MaybeT m) a
instance MonadIO m => MonadIO (MaybeT m)
instance MonadTrans MaybeT
instance MonadFix m => MonadFix (MaybeT m)
instance Monad m => MonadPlus (MaybeT m)
instance Monad m => Monad (MaybeT m)
instance (Functor m, Monad m) => Alternative (MaybeT m)
instance (Functor m, Monad m) => Applicative (MaybeT m)
instance Traversable f => Traversable (MaybeT f)
instance Foldable f => Foldable (MaybeT f)
instance Functor m => Functor (MaybeT m)
instance Show1 m => Show1 (MaybeT m)
instance Read1 m => Read1 (MaybeT m)
instance Ord1 m => Ord1 (MaybeT m)
instance Eq1 m => Eq1 (MaybeT m)
instance (Show1 m, Show a) => Show (MaybeT m a)
instance (Read1 m, Read a) => Read (MaybeT m a)
instance (Ord1 m, Ord a) => Ord (MaybeT m a)
instance (Eq1 m, Eq a) => Eq (MaybeT m a)
-- | The lazy WriterT monad transformer, which adds collection of
-- outputs (such as a count or string output) to a given monad.
--
-- This monad transformer provides only limited access to the output
-- during the computation. For more general access, use
-- Control.Monad.Trans.State instead.
--
-- This version builds its output lazily; for a strict version with the
-- same interface, see Control.Monad.Trans.Writer.Strict.
module Control.Monad.Trans.Writer.Lazy
-- | A writer monad parameterized by the type w of output to
-- accumulate.
--
-- The return function produces the output mempty, while
-- >>= combines the outputs of the subcomputations using
-- mappend.
type Writer w = WriterT w Identity
-- | Construct a writer computation from a (result, output) pair. (The
-- inverse of runWriter.)
writer :: Monad m => (a, w) -> WriterT w m a
-- | Unwrap a writer computation as a (result, output) pair. (The inverse
-- of writer.)
runWriter :: Writer w a -> (a, w)
-- | Extract the output from a writer computation.
--
--
execWriter :: Writer w a -> w
-- | Map both the return value and output of a computation using the given
-- function.
--
--
mapWriter :: ((a, w) -> (b, w')) -> Writer w a -> Writer w' b
-- | A writer monad parameterized by:
--
--
-- - w - the output to accumulate.
-- - m - The inner monad.
--
--
-- The return function produces the output mempty, while
-- >>= combines the outputs of the subcomputations using
-- mappend.
newtype WriterT w m a
WriterT :: (m (a, w)) -> WriterT w m a
-- | The inverse of WriterT.
runWriterT :: WriterT w m a -> m (a, w)
-- | Extract the output from a writer computation.
--
--
execWriterT :: Monad m => WriterT w m a -> m w
-- | Map both the return value and output of a computation using the given
-- function.
--
--
mapWriterT :: (m (a, w) -> n (b, w')) -> WriterT w m a -> WriterT w' n b
-- | tell w is an action that produces the output
-- w.
tell :: (Monoid w, Monad m) => w -> WriterT w m ()
-- | listen m is an action that executes the action
-- m and adds its output to the value of the computation.
--
--
listen :: (Monoid w, Monad m) => WriterT w m a -> WriterT w m (a, w)
-- | listens f m is an action that executes the action
-- m and adds the result of applying f to the output to
-- the value of the computation.
--
--
listens :: (Monoid w, Monad m) => (w -> b) -> WriterT w m a -> WriterT w m (a, b)
-- | pass m is an action that executes the action
-- m, which returns a value and a function, and returns the
-- value, applying the function to the output.
--
--
pass :: (Monoid w, Monad m) => WriterT w m (a, w -> w) -> WriterT w m a
-- | censor f m is an action that executes the action
-- m and applies the function f to its output, leaving
-- the return value unchanged.
--
--
censor :: (Monoid w, Monad m) => (w -> w) -> WriterT w m a -> WriterT w m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: Monoid w => CallCC m (a, w) (b, w) -> CallCC (WriterT w m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, w) -> Catch e (WriterT w m) a
instance (Monoid w, MonadIO m) => MonadIO (WriterT w m)
instance Monoid w => MonadTrans (WriterT w)
instance (Monoid w, MonadFix m) => MonadFix (WriterT w m)
instance (Monoid w, MonadPlus m) => MonadPlus (WriterT w m)
instance (Monoid w, Monad m) => Monad (WriterT w m)
instance (Monoid w, Alternative m) => Alternative (WriterT w m)
instance (Monoid w, Applicative m) => Applicative (WriterT w m)
instance Traversable f => Traversable (WriterT w f)
instance Foldable f => Foldable (WriterT w f)
instance Functor m => Functor (WriterT w m)
instance (Show w, Show1 m) => Show1 (WriterT w m)
instance (Read w, Read1 m) => Read1 (WriterT w m)
instance (Ord w, Ord1 m) => Ord1 (WriterT w m)
instance (Eq w, Eq1 m) => Eq1 (WriterT w m)
instance (Show w, Show1 m, Show a) => Show (WriterT w m a)
instance (Read w, Read1 m, Read a) => Read (WriterT w m a)
instance (Ord w, Ord1 m, Ord a) => Ord (WriterT w m a)
instance (Eq w, Eq1 m, Eq a) => Eq (WriterT w m a)
-- | The WriterT monad transformer. This version is lazy; for a strict
-- version, see Control.Monad.Trans.Writer.Strict, which has the
-- same interface.
module Control.Monad.Trans.Writer
-- | The strict WriterT monad transformer, which adds collection of
-- outputs (such as a count or string output) to a given monad.
--
-- This monad transformer provides only limited access to the output
-- during the computation. For more general access, use
-- Control.Monad.Trans.State instead.
--
-- This version builds its output strictly; for a lazy version with the
-- same interface, see Control.Monad.Trans.Writer.Lazy. Although
-- the output is built strictly, it is not possible to achieve constant
-- space behaviour with this transformer: for that, use
-- Control.Monad.Trans.State.Strict instead.
module Control.Monad.Trans.Writer.Strict
-- | A writer monad parameterized by the type w of output to
-- accumulate.
--
-- The return function produces the output mempty, while
-- >>= combines the outputs of the subcomputations using
-- mappend.
type Writer w = WriterT w Identity
-- | Construct a writer computation from a (result, output) pair. (The
-- inverse of runWriter.)
writer :: Monad m => (a, w) -> WriterT w m a
-- | Unwrap a writer computation as a (result, output) pair. (The inverse
-- of writer.)
runWriter :: Writer w a -> (a, w)
-- | Extract the output from a writer computation.
--
--
execWriter :: Writer w a -> w
-- | Map both the return value and output of a computation using the given
-- function.
--
--
mapWriter :: ((a, w) -> (b, w')) -> Writer w a -> Writer w' b
-- | A writer monad parameterized by:
--
--
-- - w - the output to accumulate.
-- - m - The inner monad.
--
--
-- The return function produces the output mempty, while
-- >>= combines the outputs of the subcomputations using
-- mappend.
newtype WriterT w m a
WriterT :: (m (a, w)) -> WriterT w m a
-- | The inverse of WriterT.
runWriterT :: WriterT w m a -> m (a, w)
-- | Extract the output from a writer computation.
--
--
execWriterT :: Monad m => WriterT w m a -> m w
-- | Map both the return value and output of a computation using the given
-- function.
--
--
mapWriterT :: (m (a, w) -> n (b, w')) -> WriterT w m a -> WriterT w' n b
-- | tell w is an action that produces the output
-- w.
tell :: (Monoid w, Monad m) => w -> WriterT w m ()
-- | listen m is an action that executes the action
-- m and adds its output to the value of the computation.
--
--
listen :: (Monoid w, Monad m) => WriterT w m a -> WriterT w m (a, w)
-- | listens f m is an action that executes the action
-- m and adds the result of applying f to the output to
-- the value of the computation.
--
--
listens :: (Monoid w, Monad m) => (w -> b) -> WriterT w m a -> WriterT w m (a, b)
-- | pass m is an action that executes the action
-- m, which returns a value and a function, and returns the
-- value, applying the function to the output.
--
--
pass :: (Monoid w, Monad m) => WriterT w m (a, w -> w) -> WriterT w m a
-- | censor f m is an action that executes the action
-- m and applies the function f to its output, leaving
-- the return value unchanged.
--
--
censor :: (Monoid w, Monad m) => (w -> w) -> WriterT w m a -> WriterT w m a
-- | Lift a callCC operation to the new monad.
liftCallCC :: Monoid w => CallCC m (a, w) (b, w) -> CallCC (WriterT w m) a b
-- | Lift a catchE operation to the new monad.
liftCatch :: Catch e m (a, w) -> Catch e (WriterT w m) a
instance (Monoid w, MonadIO m) => MonadIO (WriterT w m)
instance Monoid w => MonadTrans (WriterT w)
instance (Monoid w, MonadFix m) => MonadFix (WriterT w m)
instance (Monoid w, MonadPlus m) => MonadPlus (WriterT w m)
instance (Monoid w, Monad m) => Monad (WriterT w m)
instance (Monoid w, Alternative m) => Alternative (WriterT w m)
instance (Monoid w, Applicative m) => Applicative (WriterT w m)
instance Traversable f => Traversable (WriterT w f)
instance Foldable f => Foldable (WriterT w f)
instance Functor m => Functor (WriterT w m)
instance (Show w, Show1 m) => Show1 (WriterT w m)
instance (Read w, Read1 m) => Read1 (WriterT w m)
instance (Ord w, Ord1 m) => Ord1 (WriterT w m)
instance (Eq w, Eq1 m) => Eq1 (WriterT w m)
instance (Show w, Show1 m, Show a) => Show (WriterT w m a)
instance (Read w, Read1 m, Read a) => Read (WriterT w m a)
instance (Ord w, Ord1 m, Ord a) => Ord (WriterT w m a)
instance (Eq w, Eq1 m, Eq a) => Eq (WriterT w m a)
-- | Composition of functors.
module Data.Functor.Compose
-- | Right-to-left composition of functors. The composition of applicative
-- functors is always applicative, but the composition of monads is not
-- always a monad.
newtype Compose f g a
Compose :: (f (g a)) -> Compose f g a
-- | Inverse of Compose.
getCompose :: Compose f g a -> f (g a)
instance (Alternative f, Applicative g) => Alternative (Compose f g)
instance (Applicative f, Applicative g) => Applicative (Compose f g)
instance (Traversable f, Traversable g) => Traversable (Compose f g)
instance (Foldable f, Foldable g) => Foldable (Compose f g)
instance (Functor f, Functor g) => Functor (Compose f g)
instance (Functor f, Show1 f, Show1 g) => Show1 (Compose f g)
instance (Functor f, Read1 f, Read1 g) => Read1 (Compose f g)
instance (Functor f, Ord1 f, Ord1 g) => Ord1 (Compose f g)
instance (Functor f, Eq1 f, Eq1 g) => Eq1 (Compose f g)
instance (Functor f, Show1 f, Show1 g, Show a) => Show (Compose f g a)
instance (Functor f, Read1 f, Read1 g, Read a) => Read (Compose f g a)
instance (Functor f, Ord1 f, Ord1 g, Ord a) => Ord (Compose f g a)
instance (Functor f, Eq1 f, Eq1 g, Eq a) => Eq (Compose f g a)
instance (Show1 g, Show a) => Show (Apply g a)
instance (Read1 g, Read a) => Read (Apply g a)
instance (Ord1 g, Ord a) => Ord (Apply g a)
instance (Eq1 g, Eq a) => Eq (Apply g a)
-- | Products, lifted to functors.
module Data.Functor.Product
-- | Lifted product of functors.
data Product f g a
Pair :: (f a) -> (g a) -> Product f g a
instance (MonadFix f, MonadFix g) => MonadFix (Product f g)
instance (MonadPlus f, MonadPlus g) => MonadPlus (Product f g)
instance (Monad f, Monad g) => Monad (Product f g)
instance (Alternative f, Alternative g) => Alternative (Product f g)
instance (Applicative f, Applicative g) => Applicative (Product f g)
instance (Traversable f, Traversable g) => Traversable (Product f g)
instance (Foldable f, Foldable g) => Foldable (Product f g)
instance (Functor f, Functor g) => Functor (Product f g)
instance (Show1 f, Show1 g) => Show1 (Product f g)
instance (Read1 f, Read1 g) => Read1 (Product f g)
instance (Ord1 f, Ord1 g) => Ord1 (Product f g)
instance (Eq1 f, Eq1 g) => Eq1 (Product f g)
instance (Show1 f, Show1 g, Show a) => Show (Product f g a)
instance (Read1 f, Read1 g, Read a) => Read (Product f g a)
instance (Ord1 f, Ord1 g, Ord a) => Ord (Product f g a)
instance (Eq1 f, Eq1 g, Eq a) => Eq (Product f g a)
-- | Sums, lifted to functors.
module Data.Functor.Sum
-- | Lifted sum of functors.
data Sum f g a
InL :: (f a) -> Sum f g a
InR :: (g a) -> Sum f g a
instance (Traversable f, Traversable g) => Traversable (Sum f g)
instance (Foldable f, Foldable g) => Foldable (Sum f g)
instance (Functor f, Functor g) => Functor (Sum f g)
instance (Show1 f, Show1 g) => Show1 (Sum f g)
instance (Read1 f, Read1 g) => Read1 (Sum f g)
instance (Ord1 f, Ord1 g) => Ord1 (Sum f g)
instance (Eq1 f, Eq1 g) => Eq1 (Sum f g)
instance (Show1 f, Show1 g, Show a) => Show (Sum f g a)
instance (Read1 f, Read1 g, Read a) => Read (Sum f g a)
instance (Ord1 f, Ord1 g, Ord a) => Ord (Sum f g a)
instance (Eq1 f, Eq1 g, Eq a) => Eq (Sum f g a)
-- | Making functors with an Applicative instance that performs
-- actions in the reverse order.
module Control.Applicative.Backwards
-- | The same functor, but with an Applicative instance that
-- performs actions in the reverse order.
newtype Backwards f a
Backwards :: (f a) -> Backwards f a
-- | Inverse of Backwards.
forwards :: Backwards f a -> f a
instance Traversable f => Traversable (Backwards f)
instance Foldable f => Foldable (Backwards f)
instance Alternative f => Alternative (Backwards f)
instance Applicative f => Applicative (Backwards f)
instance Functor f => Functor (Backwards f)
instance Show1 f => Show1 (Backwards f)
instance Read1 f => Read1 (Backwards f)
instance Ord1 f => Ord1 (Backwards f)
instance Eq1 f => Eq1 (Backwards f)
instance (Show1 f, Show a) => Show (Backwards f a)
instance (Read1 f, Read a) => Read (Backwards f a)
instance (Ord1 f, Ord a) => Ord (Backwards f a)
instance (Eq1 f, Eq a) => Eq (Backwards f a)
-- | Making functors whose elements are notionally in the reverse order
-- from the original functor.
module Data.Functor.Reverse
-- | The same functor, but with Foldable and Traversable
-- instances that process the elements in the reverse order.
newtype Reverse f a
Reverse :: (f a) -> Reverse f a
-- | Inverse of Reverse.
getReverse :: Reverse f a -> f a
instance Traversable f => Traversable (Reverse f)
instance Foldable f => Foldable (Reverse f)
instance Alternative f => Alternative (Reverse f)
instance Applicative f => Applicative (Reverse f)
instance Functor f => Functor (Reverse f)
instance Show1 f => Show1 (Reverse f)
instance Read1 f => Read1 (Reverse f)
instance Ord1 f => Ord1 (Reverse f)
instance Eq1 f => Eq1 (Reverse f)
instance (Show1 f, Show a) => Show (Reverse f a)
instance (Read1 f, Read a) => Read (Reverse f a)
instance (Ord1 f, Ord a) => Ord (Reverse f a)
instance (Eq1 f, Eq a) => Eq (Reverse f a)