diff options
author | Raúl Benencia <rul@kalgan.cc> | 2013-08-24 12:17:13 -0300 |
---|---|---|
committer | Raúl Benencia <rul@kalgan.cc> | 2013-08-24 12:17:13 -0300 |
commit | fc1231ca6e008582fb6a669cb9d0607059e82cdd (patch) | |
tree | f8884e0e7735eb60c653c3fc6a9d4e7c03850b39 /Lazymail.hs | |
parent | f8a4858bc0d566b20c8201a6c42decd81442c41a (diff) |
Lazymail monad
Diffstat (limited to 'Lazymail.hs')
-rw-r--r-- | Lazymail.hs | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/Lazymail.hs b/Lazymail.hs index 9347b2e..70a6b96 100644 --- a/Lazymail.hs +++ b/Lazymail.hs @@ -6,3 +6,21 @@ - -} +module Lazymail where + +import Control.Monad.Reader +import Control.Monad.State + +import Config(LazymailConfig, customConfig) +import State(LazymailState, initialState) + +{- Lazymail monad is a ReaderT around a StateT with IO at the bottom of the + - stack. + -} +type Lazymail = ReaderT LazymailConfig (StateT LazymailState IO) + +run :: Lazymail a -> IO (a, LazymailState) +run k = + let config = customConfig + state = initialState + in runStateT (runReaderT k config) state
\ No newline at end of file |