Portability | non-portable (multi-param classes, functional dependencies) |
---|---|

Stability | experimental |

Maintainer | libraries@haskell.org |

MonadState class.

This module is inspired by the paper /Functional Programming with Overloading and Higher-Order Polymorphism/, Mark P Jones (http://www.cse.ogi.edu/~mpj/) Advanced School of Functional Programming, 1995.

# MonadState class

class Monad m => MonadState m whereSource

*get* returns the state from the internals of the monad.

*put* replaces the state inside the monad.

MonadState m => MonadState (ListT m) | |

MonadState (State s) | |

MonadState (State s) | |

MonadState m => MonadState (ReaderT r m) | |

(Error e, MonadState m) => MonadState (ErrorT e m) | |

Monad m => MonadState (StateT s m) | |

Monad m => MonadState (StateT s m) | |

(Monoid w, MonadState m) => MonadState (WriterT w m) | |

(Monoid w, MonadState m) => MonadState (WriterT w m) | |

MonadState m => MonadState (ContT r m) | |

Monoid w => MonadState (RWS r w s) | |

Monoid w => MonadState (RWS r w s) | |

(Monoid w, Monad m) => MonadState (RWST r w s m) | |

(Monoid w, Monad m) => MonadState (RWST r w s m) |

modify :: MonadState m => (StateType m -> StateType m) -> m ()Source

Monadic state transformer.

Maps an old state to a new state inside a state monad. The old state is thrown away.

Main> :t modify ((+1) :: Int -> Int) modify (...) :: (MonadState Int a) => a ()

This says that `modify (+1)`

acts over any
Monad that is a member of the `MonadState`

class,
with an `Int`

state.

gets :: MonadState m => (StateType m -> a) -> m aSource

Gets specific component of the state, using a projection function supplied.