| Safe Haskell | Safe-Inferred |
|---|---|
| Language | Haskell2010 |
Lens.Family.State.Strict
Description
Synopsis
- zoom :: forall (m :: Type -> Type) c s a. Monad m => LensLike' (Zooming m c) s a -> StateT a m c -> StateT s m c
- use :: forall (m :: Type -> Type) a s t b. Monad m => FoldLike a s t a b -> StateT s m a
- uses :: forall (m :: Type -> Type) r s t a b. Monad m => FoldLike r s t a b -> (a -> r) -> StateT s m r
- (%=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> (a -> b) -> StateT s m ()
- assign :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> b -> StateT s m ()
- (.=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> b -> StateT s m ()
- (%%=) :: forall (m :: Type -> Type) c s a b. Monad m => LensLike (Writer c) s s a b -> (a -> (c, b)) -> StateT s m c
- (<~) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> StateT s m b -> StateT s m ()
- (+=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (-=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (*=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (//=) :: forall (m :: Type -> Type) a s. (Monad m, Fractional a) => ASetter' s a -> a -> StateT s m ()
- (&&=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m ()
- (||=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m ()
- (<>=) :: forall (m :: Type -> Type) a s. (Monad m, Monoid a) => ASetter' s a -> a -> StateT s m ()
- (%!=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> (a -> b) -> StateT s m ()
- (+!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (-!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (*!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m ()
- (//!=) :: forall (m :: Type -> Type) a s. (Monad m, Fractional a) => ASetter' s a -> a -> StateT s m ()
- (&&!=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m ()
- (||!=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m ()
- (<>!=) :: forall (m :: Type -> Type) a s. (Monad m, Monoid a) => ASetter' s a -> a -> StateT s m ()
- data Zooming (m :: Type -> Type) c a
- type LensLike (f :: Type -> Type) s t a b = (a -> f b) -> s -> f t
- type LensLike' (f :: Type -> Type) s a = (a -> f a) -> s -> f s
- type FoldLike r s t a b = LensLike (Constant r :: Type -> Type) s t a b
- data Constant a (b :: k)
- type ASetter s t a b = LensLike Identity s t a b
- type ASetter' s a = LensLike' Identity s a
- data Identity a
- data StateT s (m :: Type -> Type) a
- type Writer w = WriterT w Identity
Documentation
zoom :: forall (m :: Type -> Type) c s a. Monad m => LensLike' (Zooming m c) s a -> StateT a m c -> StateT s m c Source #
zoom :: Monad m => Lens' s a -> StateT a m c -> StateT s m c
Lift a stateful operation on a field to a stateful operation on the whole state. This is a good way to call a "subroutine" that only needs access to part of the state.
zoom :: (Monad m, Monoid c) => Traversal' s a -> StateT a m c -> StateT s m c
Run the "subroutine" on each element of the traversal in turn and mconcat all the results together.
zoom :: Monad m => Traversal' s a -> StateT a m () -> StateT s m ()
Run the "subroutine" on each element the traversal in turn.
use :: forall (m :: Type -> Type) a s t b. Monad m => FoldLike a s t a b -> StateT s m a Source #
use :: Monad m => Getter s t a b -> StateT s m a
Retrieve a field of the state
use :: (Monad m, Monoid a) => Fold s t a b -> StateT s m a
Retrieve a monoidal summary of all the referenced fields from the state
uses :: forall (m :: Type -> Type) r s t a b. Monad m => FoldLike r s t a b -> (a -> r) -> StateT s m r Source #
uses :: (Monad m, Monoid r) => Fold s t a b -> (a -> r) -> StateT s m r
Retrieve all the referenced fields from the state and foldMap the results together with f :: a -> r.
uses :: Monad m => Getter s t a b -> (a -> r) -> StateT s m r
Retrieve a field of the state and pass it through the function f :: a -> r.
uses l f = f <$> use l
(%=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> (a -> b) -> StateT s m () infix 4 Source #
Modify a field of the state.
assign :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> b -> StateT s m () Source #
Set a field of the state.
(.=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> b -> StateT s m () infix 4 Source #
Set a field of the state.
(%%=) :: forall (m :: Type -> Type) c s a b. Monad m => LensLike (Writer c) s s a b -> (a -> (c, b)) -> StateT s m c infix 4 Source #
(%%=) :: Monad m => Lens s s a b -> (a -> (c, b)) -> StateT s m c
Modify a field of the state while returning another value.
(%%=) :: (Monad m, Monoid c) => Traversal s s a b -> (a -> (c, b)) -> StateT s m c
Modify each field of the state and return the mconcat of the other values.
(<~) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> StateT s m b -> StateT s m () infixr 2 Source #
Set a field of the state using the result of executing a stateful command.
Compound Assignments
(+=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(-=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(*=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(//=) :: forall (m :: Type -> Type) a s. (Monad m, Fractional a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(&&=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m () infixr 4 Source #
(||=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m () infixr 4 Source #
(<>=) :: forall (m :: Type -> Type) a s. (Monad m, Monoid a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
Monoidally append a value to all referenced fields of the state.
Strict Assignments
(%!=) :: forall (m :: Type -> Type) s a b. Monad m => ASetter s s a b -> (a -> b) -> StateT s m () infix 4 Source #
Strictly modify a field of the state.
(+!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(-!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(*!=) :: forall (m :: Type -> Type) a s. (Monad m, Num a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(//!=) :: forall (m :: Type -> Type) a s. (Monad m, Fractional a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
(&&!=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m () infixr 4 Source #
(||!=) :: forall (m :: Type -> Type) s. Monad m => ASetter' s Bool -> Bool -> StateT s m () infixr 4 Source #
(<>!=) :: forall (m :: Type -> Type) a s. (Monad m, Monoid a) => ASetter' s a -> a -> StateT s m () infixr 4 Source #
Types
data Zooming (m :: Type -> Type) c a Source #
Instances
| (Monoid c, Monad m) => Applicative (Zooming m c) Source # | |
Defined in Lens.Family.State.Zoom Methods pure :: a -> Zooming m c a Source # (<*>) :: Zooming m c (a -> b) -> Zooming m c a -> Zooming m c b Source # liftA2 :: (a -> b -> c0) -> Zooming m c a -> Zooming m c b -> Zooming m c c0 Source # (*>) :: Zooming m c a -> Zooming m c b -> Zooming m c b Source # (<*) :: Zooming m c a -> Zooming m c b -> Zooming m c a Source # | |
| Monad m => Functor (Zooming m c) Source # | |
Re-exports
data Constant a (b :: k) Source #
Constant functor.
Instances
Identity functor and monad. (a non-strict monad)
Examples
>>>fmap (+1) (Identity 0)Identity 1
>>>Identity [1, 2, 3] <> Identity [4, 5, 6]Identity [1,2,3,4,5,6]
>>> do
x <- Identity 10
y <- Identity (x + 5)
pure (x + y)
Identity 25
Since: base-4.8.0.0
Instances
| MonadZip Identity | Since: base-4.8.0.0 | ||||
| Foldable1 Identity | Since: base-4.18.0.0 | ||||
Defined in Data.Foldable1 Methods fold1 :: Semigroup m => Identity m -> m Source # foldMap1 :: Semigroup m => (a -> m) -> Identity a -> m Source # foldMap1' :: Semigroup m => (a -> m) -> Identity a -> m Source # toNonEmpty :: Identity a -> NonEmpty a Source # maximum :: Ord a => Identity a -> a Source # minimum :: Ord a => Identity a -> a Source # head :: Identity a -> a Source # last :: Identity a -> a Source # foldrMap1 :: (a -> b) -> (a -> b -> b) -> Identity a -> b Source # foldlMap1' :: (a -> b) -> (b -> a -> b) -> Identity a -> b Source # foldlMap1 :: (a -> b) -> (b -> a -> b) -> Identity a -> b Source # foldrMap1' :: (a -> b) -> (a -> b -> b) -> Identity a -> b Source # | |||||
| Eq1 Identity | Since: base-4.9.0.0 | ||||
| Ord1 Identity | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Classes | |||||
| Read1 Identity | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Classes Methods liftReadsPrec :: (Int -> ReadS a) -> ReadS [a] -> Int -> ReadS (Identity a) Source # liftReadList :: (Int -> ReadS a) -> ReadS [a] -> ReadS [Identity a] Source # liftReadPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec (Identity a) Source # liftReadListPrec :: ReadPrec a -> ReadPrec [a] -> ReadPrec [Identity a] Source # | |||||
| Show1 Identity | Since: base-4.9.0.0 | ||||
| NFData1 Identity | Since: deepseq-1.4.3.0 | ||||
Defined in Control.DeepSeq | |||||
| Applicative Identity | Since: base-4.8.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity | |||||
| Functor Identity | Since: base-4.8.0.0 | ||||
| Monad Identity | Since: base-4.8.0.0 | ||||
| MonadFix Identity | Since: base-4.8.0.0 | ||||
| Foldable Identity | Since: base-4.8.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods fold :: Monoid m => Identity m -> m Source # foldMap :: Monoid m => (a -> m) -> Identity a -> m Source # foldMap' :: Monoid m => (a -> m) -> Identity a -> m Source # foldr :: (a -> b -> b) -> b -> Identity a -> b Source # foldr' :: (a -> b -> b) -> b -> Identity a -> b Source # foldl :: (b -> a -> b) -> b -> Identity a -> b Source # foldl' :: (b -> a -> b) -> b -> Identity a -> b Source # foldr1 :: (a -> a -> a) -> Identity a -> a Source # foldl1 :: (a -> a -> a) -> Identity a -> a Source # toList :: Identity a -> [a] Source # null :: Identity a -> Bool Source # length :: Identity a -> Int Source # elem :: Eq a => a -> Identity a -> Bool Source # maximum :: Ord a => Identity a -> a Source # minimum :: Ord a => Identity a -> a Source # | |||||
| Traversable Identity | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Traversable | |||||
| Identical Identity Source # | |||||
Defined in Lens.Family.Identical | |||||
| Generic1 Identity | |||||
Defined in GHC.Internal.Data.Functor.Identity Associated Types
| |||||
| NFData a => NFData (Identity a) | Since: deepseq-1.4.0.0 | ||||
Defined in Control.DeepSeq | |||||
| Monoid a => Monoid (Identity a) | Since: base-4.9.0.0 | ||||
| Semigroup a => Semigroup (Identity a) | Since: base-4.9.0.0 | ||||
| Bits a => Bits (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods (.&.) :: Identity a -> Identity a -> Identity a Source # (.|.) :: Identity a -> Identity a -> Identity a Source # xor :: Identity a -> Identity a -> Identity a Source # complement :: Identity a -> Identity a Source # shift :: Identity a -> Int -> Identity a Source # rotate :: Identity a -> Int -> Identity a Source # zeroBits :: Identity a Source # bit :: Int -> Identity a Source # setBit :: Identity a -> Int -> Identity a Source # clearBit :: Identity a -> Int -> Identity a Source # complementBit :: Identity a -> Int -> Identity a Source # testBit :: Identity a -> Int -> Bool Source # bitSizeMaybe :: Identity a -> Maybe Int Source # bitSize :: Identity a -> Int Source # isSigned :: Identity a -> Bool Source # shiftL :: Identity a -> Int -> Identity a Source # unsafeShiftL :: Identity a -> Int -> Identity a Source # shiftR :: Identity a -> Int -> Identity a Source # unsafeShiftR :: Identity a -> Int -> Identity a Source # rotateL :: Identity a -> Int -> Identity a Source # | |||||
| FiniteBits a => FiniteBits (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods finiteBitSize :: Identity a -> Int Source # countLeadingZeros :: Identity a -> Int Source # countTrailingZeros :: Identity a -> Int Source # | |||||
| Bounded a => Bounded (Identity a) | Since: base-4.9.0.0 | ||||
| Enum a => Enum (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods succ :: Identity a -> Identity a Source # pred :: Identity a -> Identity a Source # toEnum :: Int -> Identity a Source # fromEnum :: Identity a -> Int Source # enumFrom :: Identity a -> [Identity a] Source # enumFromThen :: Identity a -> Identity a -> [Identity a] Source # enumFromTo :: Identity a -> Identity a -> [Identity a] Source # enumFromThenTo :: Identity a -> Identity a -> Identity a -> [Identity a] Source # | |||||
| Floating a => Floating (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods exp :: Identity a -> Identity a Source # log :: Identity a -> Identity a Source # sqrt :: Identity a -> Identity a Source # (**) :: Identity a -> Identity a -> Identity a Source # logBase :: Identity a -> Identity a -> Identity a Source # sin :: Identity a -> Identity a Source # cos :: Identity a -> Identity a Source # tan :: Identity a -> Identity a Source # asin :: Identity a -> Identity a Source # acos :: Identity a -> Identity a Source # atan :: Identity a -> Identity a Source # sinh :: Identity a -> Identity a Source # cosh :: Identity a -> Identity a Source # tanh :: Identity a -> Identity a Source # asinh :: Identity a -> Identity a Source # acosh :: Identity a -> Identity a Source # atanh :: Identity a -> Identity a Source # log1p :: Identity a -> Identity a Source # expm1 :: Identity a -> Identity a Source # | |||||
| RealFloat a => RealFloat (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods floatRadix :: Identity a -> Integer Source # floatDigits :: Identity a -> Int Source # floatRange :: Identity a -> (Int, Int) Source # decodeFloat :: Identity a -> (Integer, Int) Source # encodeFloat :: Integer -> Int -> Identity a Source # exponent :: Identity a -> Int Source # significand :: Identity a -> Identity a Source # scaleFloat :: Int -> Identity a -> Identity a Source # isNaN :: Identity a -> Bool Source # isInfinite :: Identity a -> Bool Source # isDenormalized :: Identity a -> Bool Source # isNegativeZero :: Identity a -> Bool Source # | |||||
| Storable a => Storable (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods sizeOf :: Identity a -> Int Source # alignment :: Identity a -> Int Source # peekElemOff :: Ptr (Identity a) -> Int -> IO (Identity a) Source # pokeElemOff :: Ptr (Identity a) -> Int -> Identity a -> IO () Source # peekByteOff :: Ptr b -> Int -> IO (Identity a) Source # pokeByteOff :: Ptr b -> Int -> Identity a -> IO () Source # | |||||
| Generic (Identity a) | |||||
Defined in GHC.Internal.Data.Functor.Identity Associated Types
| |||||
| Ix a => Ix (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods range :: (Identity a, Identity a) -> [Identity a] Source # index :: (Identity a, Identity a) -> Identity a -> Int Source # unsafeIndex :: (Identity a, Identity a) -> Identity a -> Int Source # inRange :: (Identity a, Identity a) -> Identity a -> Bool Source # | |||||
| Num a => Num (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods (+) :: Identity a -> Identity a -> Identity a Source # (-) :: Identity a -> Identity a -> Identity a Source # (*) :: Identity a -> Identity a -> Identity a Source # negate :: Identity a -> Identity a Source # abs :: Identity a -> Identity a Source # signum :: Identity a -> Identity a Source # fromInteger :: Integer -> Identity a Source # | |||||
| Read a => Read (Identity a) | This instance would be equivalent to the derived instances of the
Since: base-4.8.0.0 | ||||
| Fractional a => Fractional (Identity a) | Since: base-4.9.0.0 | ||||
| Integral a => Integral (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods quot :: Identity a -> Identity a -> Identity a Source # rem :: Identity a -> Identity a -> Identity a Source # div :: Identity a -> Identity a -> Identity a Source # mod :: Identity a -> Identity a -> Identity a Source # quotRem :: Identity a -> Identity a -> (Identity a, Identity a) Source # divMod :: Identity a -> Identity a -> (Identity a, Identity a) Source # | |||||
| Real a => Real (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods toRational :: Identity a -> Rational Source # | |||||
| RealFrac a => RealFrac (Identity a) | Since: base-4.9.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity | |||||
| Show a => Show (Identity a) | This instance would be equivalent to the derived instances of the
Since: base-4.8.0.0 | ||||
| Eq a => Eq (Identity a) | Since: base-4.8.0.0 | ||||
| Ord a => Ord (Identity a) | Since: base-4.8.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity Methods compare :: Identity a -> Identity a -> Ordering Source # (<) :: Identity a -> Identity a -> Bool Source # (<=) :: Identity a -> Identity a -> Bool Source # (>) :: Identity a -> Identity a -> Bool Source # (>=) :: Identity a -> Identity a -> Bool Source # | |||||
| type Rep1 Identity | Since: base-4.8.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity | |||||
| type Rep (Identity a) | Since: base-4.8.0.0 | ||||
Defined in GHC.Internal.Data.Functor.Identity | |||||
data StateT s (m :: Type -> Type) a Source #
A state transformer monad parameterized by:
s- The state.m- The inner monad.
The return function leaves the state unchanged, while >>= uses
the final state of the first computation as the initial state of
the second.
Instances
| MonadTrans (StateT s) | |||||
| MonadIO m => MonadIO (StateT s m) | |||||
| Contravariant m => Contravariant (StateT s m) | |||||
| (Functor m, MonadPlus m) => Alternative (StateT s m) | |||||
| (Functor m, Monad m) => Applicative (StateT s m) | |||||
Defined in Control.Monad.Trans.State.Strict Methods pure :: a -> StateT s m a Source # (<*>) :: StateT s m (a -> b) -> StateT s m a -> StateT s m b Source # liftA2 :: (a -> b -> c) -> StateT s m a -> StateT s m b -> StateT s m c Source # (*>) :: StateT s m a -> StateT s m b -> StateT s m b Source # (<*) :: StateT s m a -> StateT s m b -> StateT s m a Source # | |||||
| Functor m => Functor (StateT s m) | |||||
| Monad m => Monad (StateT s m) | |||||
| MonadPlus m => MonadPlus (StateT s m) | |||||
| MonadFail m => MonadFail (StateT s m) | |||||
| MonadFix m => MonadFix (StateT s m) | |||||
| Generic (StateT s m a) | |||||
Defined in Control.Monad.Trans.State.Strict Associated Types
| |||||
| type Rep (StateT s m a) | |||||
Defined in Control.Monad.Trans.State.Strict | |||||