2012-01-30 02:55:06 +00:00
|
|
|
{- state monad support
|
|
|
|
-
|
|
|
|
- Copyright 2012 Joey Hess <joey@kitenet.net>
|
|
|
|
-
|
|
|
|
- Licensed under the GNU GPL version 3 or higher.
|
|
|
|
-}
|
|
|
|
|
|
|
|
module Utility.State where
|
|
|
|
|
2012-10-24 18:43:32 +00:00
|
|
|
import "mtl" Control.Monad.State.Strict
|
2012-01-30 02:55:06 +00:00
|
|
|
|
|
|
|
{- Modifies Control.Monad.State's state, forcing a strict update.
|
|
|
|
- This avoids building thunks in the state and leaking.
|
|
|
|
- Why it's not the default, I don't know.
|
|
|
|
-
|
|
|
|
- Example: changeState $ \s -> s { foo = bar }
|
|
|
|
-}
|
|
|
|
changeState :: MonadState s m => (s -> s) -> m ()
|
|
|
|
changeState f = do
|
|
|
|
x <- get
|
|
|
|
put $! f x
|
|
|
|
|
|
|
|
{- Gets a value from the internal state, selected by the passed value
|
|
|
|
- constructor. -}
|
|
|
|
getState :: MonadState s m => (s -> a) -> m a
|
|
|
|
getState = gets
|