Safe Haskell | None |
---|---|
Language | Haskell2010 |
Control.Monad.Indexed.Trans.Writer
Description
Documentation
newtype WriterT κ f i j a Source #
Constructors
WriterT | |
Fields
|
Instances
(Semigroupoid κ, Monad m) => Bind (WriterT κ m :: k -> k -> Type -> Type) Source # | |
(Semigroupoid κ, Applicative p) => Apply (WriterT κ p :: k -> k -> Type -> Type) Source # | |
Defined in Control.Monad.Indexed.Trans.Writer Methods (<*>) :: forall (i :: k0) (j :: k0) a b (k1 :: k0). WriterT κ p i j (a -> b) -> WriterT κ p j k1 a -> WriterT κ p i k1 b Source # (*>) :: forall (i :: k0) (j :: k0) a (k1 :: k0) b. WriterT κ p i j a -> WriterT κ p j k1 b -> WriterT κ p i k1 b Source # (<*) :: forall (i :: k0) (j :: k0) a (k1 :: k0) b. WriterT κ p i j a -> WriterT κ p j k1 b -> WriterT κ p i k1 a Source # liftA2 :: forall a b c (i :: k0) (j :: k0) (k1 :: k0). (a -> b -> c) -> WriterT κ p i j a -> WriterT κ p j k1 b -> WriterT κ p i k1 c Source # | |
(Monad m, Category κ) => Monad (WriterT κ m k2 k2) Source # | |
Functor f => Functor (WriterT κ f i j) Source # | |
(MonadFix m, Category κ) => MonadFix (WriterT κ m k2 k2) Source # | |
Defined in Control.Monad.Indexed.Trans.Writer | |
(Applicative p, Category κ) => Applicative (WriterT κ p k2 k2) Source # | |
Defined in Control.Monad.Indexed.Trans.Writer Methods pure :: a -> WriterT κ p k2 k2 a # (<*>) :: WriterT κ p k2 k2 (a -> b) -> WriterT κ p k2 k2 a -> WriterT κ p k2 k2 b # liftA2 :: (a -> b -> c) -> WriterT κ p k2 k2 a -> WriterT κ p k2 k2 b -> WriterT κ p k2 k2 c # (*>) :: WriterT κ p k2 k2 a -> WriterT κ p k2 k2 b -> WriterT κ p k2 k2 b # (<*) :: WriterT κ p k2 k2 a -> WriterT κ p k2 k2 b -> WriterT κ p k2 k2 a # | |
Foldable f => Foldable (WriterT κ f i j) Source # | |
Defined in Control.Monad.Indexed.Trans.Writer Methods fold :: Monoid m => WriterT κ f i j m -> m # foldMap :: Monoid m => (a -> m) -> WriterT κ f i j a -> m # foldMap' :: Monoid m => (a -> m) -> WriterT κ f i j a -> m # foldr :: (a -> b -> b) -> b -> WriterT κ f i j a -> b # foldr' :: (a -> b -> b) -> b -> WriterT κ f i j a -> b # foldl :: (b -> a -> b) -> b -> WriterT κ f i j a -> b # foldl' :: (b -> a -> b) -> b -> WriterT κ f i j a -> b # foldr1 :: (a -> a -> a) -> WriterT κ f i j a -> a # foldl1 :: (a -> a -> a) -> WriterT κ f i j a -> a # toList :: WriterT κ f i j a -> [a] # null :: WriterT κ f i j a -> Bool # length :: WriterT κ f i j a -> Int # elem :: Eq a => a -> WriterT κ f i j a -> Bool # maximum :: Ord a => WriterT κ f i j a -> a # minimum :: Ord a => WriterT κ f i j a -> a # | |
Traversable f => Traversable (WriterT κ f i j) Source # | |
Defined in Control.Monad.Indexed.Trans.Writer Methods traverse :: Applicative f0 => (a -> f0 b) -> WriterT κ f i j a -> f0 (WriterT κ f i j b) # sequenceA :: Applicative f0 => WriterT κ f i j (f0 a) -> f0 (WriterT κ f i j a) # mapM :: Monad m => (a -> m b) -> WriterT κ f i j a -> m (WriterT κ f i j b) # sequence :: Monad m => WriterT κ f i j (m a) -> m (WriterT κ f i j a) # | |
(Alternative p, Category κ) => Alternative (WriterT κ p k2 k2) Source # | |
(MonadPlus p, Category κ) => MonadPlus (WriterT κ p k2 k2) Source # | |
mapWriterT :: (f (a, κ i j) -> f' (a', κ' i' j')) -> WriterT κ f i j a -> WriterT κ' f' i' j' a' Source #
tell :: Applicative p => κ i j -> WriterT κ p i j () Source #