Copyright | (c) Andy Gill 2001, (c) Oregon Graduate Institute of Science and Technology 2001, (c) Jeff Newbern 2003-2007, (c) Andriy Palamarchuk 2007 |
---|---|
License | BSD-style (see the file LICENSE) |
Maintainer | ross@soi.city.ac.uk |
Stability | experimental |
Portability | non-portable (type families) |
Safe Haskell | Safe |
Language | Haskell98 |
- Computation type:
- Computations which read values from a shared environment.
- Binding strategy:
- Monad values are functions from the environment to a value. The bound function is applied to the bound value, and both have access to the shared environment.
- Useful for:
- Maintaining variable bindings, or other shared environment.
- Zero and plus:
- None.
- Example type:
Reader
[(String,Value)] a
The Reader
monad (also called the Environment monad).
Represents a computation, which can read values from
a shared environment, pass values from function to function,
and execute sub-computations in a modified environment.
Using Reader
monad for such computations is often clearer and easier
than using the State
monad.
Inspired by the paper /Functional Programming with Overloading and Higher-Order Polymorphism/, Mark P Jones (http://web.cecs.pdx.edu/~mpj/) Advanced School of Functional Programming, 1995.
- class Monad m => MonadReader m where
- type EnvType m
- asks :: MonadReader m => (EnvType m -> a) -> m a
Documentation
class Monad m => MonadReader m where Source #
See examples in Control.Monad.Reader.
Note, the partially applied function type (->) r
is a simple reader monad.
See the instance
declaration below.
Retrieves the monad environment.
local :: (EnvType m -> EnvType m) -> m a -> m a Source #
Executes a computation in a modified environment.
MonadReader ((->) r) Source # | |
MonadReader m => MonadReader (MaybeT m) Source # | |
MonadReader m => MonadReader (ListT m) Source # | |
(Monoid w, MonadReader m) => MonadReader (WriterT w m) Source # | |
(Monoid w, MonadReader m) => MonadReader (WriterT w m) Source # | |
MonadReader m => MonadReader (StateT s m) Source # | |
MonadReader m => MonadReader (StateT s m) Source # | |
MonadReader m => MonadReader (IdentityT * m) Source # | |
(Error e, MonadReader m) => MonadReader (ErrorT e m) Source # | |
Monad m => MonadReader (ReaderT * r m) Source # | |
MonadReader m => MonadReader (ContT * r m) Source # | |
(Monoid w, Monad m) => MonadReader (RWST r w s m) Source # | |
(Monoid w, Monad m) => MonadReader (RWST r w s m) Source # | |
:: MonadReader m | |
=> (EnvType m -> a) | The selector function to apply to the environment. |
-> m a |
Retrieves a function of the current environment.