multistate-0.1.1: like mtl's ReaderT/StateT, but more than one contained value/type.

Safe HaskellNone
LanguageHaskell98

Control.Monad.MultiState

Documentation

newtype MultiStateT x m a Source

Constructors

MultiStateT 

Fields

runMultiStateTRaw :: StateT (HList x) m a
 

Instances

class Monad m => MonadMultiState a m where Source

Methods

mSet :: a -> m () Source

mGet :: m a Source

Instances

(MonadTrans t, Monad (t m), MonadMultiState a m) => MonadMultiState a (t m) 
(Monad m, ContainsType a c) => MonadMultiState a (MultiStateT c m) 

mGetRaw :: Monad m => MultiStateT a m (HList a) Source

withMultiState :: Monad m => x -> MultiStateT (Cons x xs) m a -> MultiStateT xs m a Source

withMultiStates :: Monad m => HList xs -> MultiStateT (Append xs ys) m a -> MultiStateT ys m a Source

evalMultiStateTWithInitial :: Monad m => HList a -> MultiStateT a m b -> m b Source

mapMultiStateT :: (m (a, HList w) -> m' (a', HList w)) -> MultiStateT w m a -> MultiStateT w m' a' Source

data Cons car cdr :: * -> * -> *

Instances

(Show car, Show cdr) => Show (Cons car cdr) 
Typeable (* -> * -> *) Cons 
type IsNull (Cons car cdr) = False 
type Head (Cons car cdr) = car 
type Tail (Cons car cdr) = cdr 
type Reverse' (Cons car cdr) a = Reverse' cdr (Cons car a) 
type Append (Cons car1 cdr2) l2 = Cons car1 (Append cdr2 l2) 

data Null :: *

Instances

Show Null 
Typeable * Null 
type IsNull Null = True 
type Reverse' Null a = a 
type Append Null l2 = l2