Copyright | (c) Edward Kmett 2011 (c) Conal Elliott 2008 |
---|---|
License | BSD3 |
Maintainer | ekmett@gmail.com |
Stability | experimental |
Safe Haskell | Safe-Inferred |
Language | Haskell98 |
Control.Monad.Representable.Reader
Description
Representable functors on Hask are all monads, because they are isomorphic to
a Reader
monad.
Synopsis
- type Reader f = ReaderT f Identity
- runReader :: Representable f => Reader f b -> Rep f -> b
- newtype ReaderT f m b = ReaderT {
- getReaderT :: f (m b)
- readerT :: Representable f => (Rep f -> m b) -> ReaderT f m b
- runReaderT :: Representable f => ReaderT f m b -> Rep f -> m b
- class Monad m => MonadReader r (m :: Type -> Type) | m -> r where
- module Data.Functor.Rep
Representable functor monad
Monad Transformer
newtype ReaderT f m b Source #
Constructors
ReaderT | |
Fields
|
Instances
(Representable f, MonadWriter w m) => MonadWriter w (ReaderT f m) Source # | |
Representable f => MonadTrans (ReaderT f) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Representable f, Monad m) => Monad (ReaderT f m) Source # | |
(Functor f, Functor m) => Functor (ReaderT f m) Source # | |
(Representable f, Applicative m) => Applicative (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Foldable f, Foldable m) => Foldable (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader Methods fold :: Monoid m0 => ReaderT f m m0 -> m0 foldMap :: Monoid m0 => (a -> m0) -> ReaderT f m a -> m0 foldMap' :: Monoid m0 => (a -> m0) -> ReaderT f m a -> m0 foldr :: (a -> b -> b) -> b -> ReaderT f m a -> b foldr' :: (a -> b -> b) -> b -> ReaderT f m a -> b foldl :: (b -> a -> b) -> b -> ReaderT f m a -> b foldl' :: (b -> a -> b) -> b -> ReaderT f m a -> b foldr1 :: (a -> a -> a) -> ReaderT f m a -> a foldl1 :: (a -> a -> a) -> ReaderT f m a -> a toList :: ReaderT f m a -> [a] length :: ReaderT f m a -> Int elem :: Eq a => a -> ReaderT f m a -> Bool maximum :: Ord a => ReaderT f m a -> a minimum :: Ord a => ReaderT f m a -> a | |
(Traversable f, Traversable m) => Traversable (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Representable f, Representable m, Monoid (Rep f), Monoid (Rep m)) => Comonad (ReaderT f m) Source # | |
(Representable f, Apply m) => Apply (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Representable f, MonadIO m) => MonadIO (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Representable f, Bind m) => Bind (ReaderT f m) Source # | |
(Representable f, Representable m, Semigroup (Rep f), Semigroup (Rep m)) => Extend (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Representable f, Distributive m) => Distributive (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Foldable1 f, Foldable1 m) => Foldable1 (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader | |
(Traversable1 f, Traversable1 m) => Traversable1 (ReaderT f m) Source # | |
(Representable f, Representable m) => Representable (ReaderT f m) Source # | |
type Rep (ReaderT f m) Source # | |
Defined in Control.Monad.Representable.Reader |
runReaderT :: Representable f => ReaderT f m b -> Rep f -> m b Source #
class Monad m => MonadReader r (m :: Type -> Type) | m -> r where #
Instances
(Representable f, Rep f ~ a) => MonadReader a (Co f) Source # | |
(Functor m, MonadReader e m) => MonadReader e (Free m) | |
MonadReader r m => MonadReader r (MaybeT m) | |
MonadReader r m => MonadReader r (ListT m) | |
(Representable g, MonadReader e m) => MonadReader e (StateT g m) Source # | |
(Functor f, MonadReader r m) => MonadReader r (FreeT f m) | |
(Monoid w, MonadReader r m) => MonadReader r (WriterT w m) | |
(Monoid w, MonadReader r m) => MonadReader r (WriterT w m) | |
MonadReader r m => MonadReader r (StateT s m) | |
MonadReader r m => MonadReader r (StateT s m) | |
Monad m => MonadReader r (ReaderT r m) | |
MonadReader r m => MonadReader r (IdentityT m) | |
MonadReader r m => MonadReader r (ExceptT e m) | |
(Error e, MonadReader r m) => MonadReader r (ErrorT e m) | |
MonadReader r ((->) r :: Type -> Type) | |
MonadReader r' m => MonadReader r' (ContT r m) | |
(Monad m, Monoid w) => MonadReader r (RWST r w s m) | |
(Monad m, Monoid w) => MonadReader r (RWST r w s m) | |
module Data.Functor.Rep