Safe Haskell | None |
---|---|
Language | Haskell2010 |
Foundation.Monad
Synopsis
- class Monad m => MonadIO (m :: Type -> Type) where
- class Monad m => MonadFailure (m :: Type -> Type) where
- class Monad m => MonadThrow (m :: Type -> Type) where
- class MonadThrow m => MonadCatch (m :: Type -> Type) where
- class MonadCatch m => MonadBracket (m :: Type -> Type) where
- generalBracket :: m a -> (a -> b -> m ignored1) -> (a -> SomeException -> m ignored2) -> (a -> m b) -> m b
- class MonadTrans (trans :: (Type -> Type) -> Type -> Type) where
- newtype Identity a = Identity {
- runIdentity :: a
- replicateM :: Applicative m => CountOf a -> m a -> m [a]
Documentation
class Monad m => MonadIO (m :: Type -> Type) where #
Monads in which IO
computations may be embedded.
Any monad built by applying a sequence of monad transformers to the
IO
monad will be an instance of this class.
Instances should satisfy the following laws, which state that liftIO
is a transformer of monads:
Methods
Lift a computation from the IO
monad.
This allows us to run IO computations in any monadic stack, so long as it supports these kinds of operations
(i.e. IO
is the base monad for the stack).
Example
import Control.Monad.Trans.State -- from the "transformers" library printState :: Show s => StateT s IO () printState = do state <- get liftIO $ print state
Had we omitted
, we would have ended up with this error:liftIO
• Couldn't match type ‘IO’ with ‘StateT s IO’ Expected type: StateT s IO () Actual type: IO ()
The important part here is the mismatch between StateT s IO ()
and
.IO
()
Luckily, we know of a function that takes an
and returns an IO
a(m a)
:
,
enabling us to run the program and see the expected results:liftIO
> evalStateT printState "hello" "hello" > evalStateT printState 3 3
Instances
MonadIO IO | Since: base-4.9.0.0 |
Defined in Control.Monad.IO.Class | |
MonadIO m => MonadIO (ResourceT m) Source # | |
Defined in Foundation.Conduit.Internal | |
MonadIO m => MonadIO (ExceptT e m) Source # | |
Defined in Foundation.Monad.Except | |
MonadIO m => MonadIO (ReaderT r m) Source # | |
Defined in Foundation.Monad.Reader | |
(Functor m, MonadIO m) => MonadIO (StateT s m) Source # | |
Defined in Foundation.Monad.State | |
MonadIO m => MonadIO (Conduit i o m) Source # | |
Defined in Foundation.Conduit.Internal |
class Monad m => MonadFailure (m :: Type -> Type) where Source #
Monad that can represent failure
Similar to MonadFail but with a parametrized Failure linked to the Monad
Associated Types
type Failure (m :: Type -> Type) Source #
The associated type with the MonadFailure, representing what failure can be encoded in this monad
Instances
MonadFailure Maybe | |||||
MonadFailure (Either a) | |||||
Monad m => MonadFailure (ExceptT e m) Source # | |||||
MonadFailure m => MonadFailure (ReaderT r m) Source # | |||||
(Functor m, MonadFailure m) => MonadFailure (StateT s m) Source # | |||||
MonadFailure m => MonadFailure (Conduit i o m) Source # | |||||
Monad state => MonadFailure (Builder collection mutCollection step state err) | |||||
Defined in Basement.MutableBuilder Associated Types
|
class Monad m => MonadThrow (m :: Type -> Type) where Source #
Monad that can throw exception
Methods
throw :: Exception e => e -> m a Source #
Throw immediatity an exception.
Only a MonadCatch
monad will be able to catch the exception using catch
Instances
MonadThrow IO Source # | |
MonadThrow m => MonadThrow (ResourceT m) Source # | |
MonadThrow m => MonadThrow (ReaderT r m) Source # | |
(Functor m, MonadThrow m) => MonadThrow (StateT s m) Source # | |
MonadThrow m => MonadThrow (Conduit i o m) Source # | |
class MonadThrow m => MonadCatch (m :: Type -> Type) where Source #
Monad that can catch exception
Instances
MonadCatch IO Source # | |
MonadCatch m => MonadCatch (ResourceT m) Source # | |
MonadCatch m => MonadCatch (ReaderT r m) Source # | |
(Functor m, MonadCatch m) => MonadCatch (StateT s m) Source # | |
MonadCatch m => MonadCatch (Conduit i o m) Source # | |
class MonadCatch m => MonadBracket (m :: Type -> Type) where Source #
Monad that can ensure cleanup actions are performed even in the case of exceptions, both synchronous and asynchronous. This usually excludes continuation-based monads.
Methods
Arguments
:: m a | acquire some resource |
-> (a -> b -> m ignored1) | cleanup, no exception thrown |
-> (a -> SomeException -> m ignored2) | cleanup, some exception thrown. The exception will be rethrown |
-> (a -> m b) | inner action to perform with the resource |
-> m b |
A generalized version of the standard bracket function which allows distinguishing different exit cases.
Instances
MonadBracket IO Source # | |
Defined in Foundation.Monad.Exception Methods generalBracket :: IO a -> (a -> b -> IO ignored1) -> (a -> SomeException -> IO ignored2) -> (a -> IO b) -> IO b Source # | |
MonadBracket m => MonadBracket (ResourceT m) Source # | |
Defined in Foundation.Conduit.Internal Methods generalBracket :: ResourceT m a -> (a -> b -> ResourceT m ignored1) -> (a -> SomeException -> ResourceT m ignored2) -> (a -> ResourceT m b) -> ResourceT m b Source # | |
MonadBracket m => MonadBracket (ReaderT r m) Source # | |
Defined in Foundation.Monad.Reader Methods generalBracket :: ReaderT r m a -> (a -> b -> ReaderT r m ignored1) -> (a -> SomeException -> ReaderT r m ignored2) -> (a -> ReaderT r m b) -> ReaderT r m b Source # |
class MonadTrans (trans :: (Type -> Type) -> Type -> Type) where Source #
Basic Transformer class
Methods
lift :: Monad m => m a -> trans m a Source #
Lift a computation from an inner monad to the current transformer monad
Instances
MonadTrans ResourceT Source # | |
MonadTrans (ExceptT e) Source # | |
MonadTrans (ReaderT r) Source # | |
MonadTrans (StateT s) Source # | |
MonadTrans (Conduit i o) Source # | |
Identity functor and monad. (a non-strict monad)
Since: base-4.8.0.0
Constructors
Identity | |
Fields
|
Instances
MonadFix Identity | Since: base-4.8.0.0 | ||||
Defined in Data.Functor.Identity | |||||
MonadZip Identity | Since: base-4.8.0.0 | ||||
Foldable Identity | Since: base-4.8.0.0 | ||||
Defined in Data.Functor.Identity Methods fold :: Monoid m => Identity m -> m # foldMap :: Monoid m => (a -> m) -> Identity a -> m # foldMap' :: Monoid m => (a -> m) -> Identity a -> m # foldr :: (a -> b -> b) -> b -> Identity a -> b # foldr' :: (a -> b -> b) -> b -> Identity a -> b # foldl :: (b -> a -> b) -> b -> Identity a -> b # foldl' :: (b -> a -> b) -> b -> Identity a -> b # foldr1 :: (a -> a -> a) -> Identity a -> a # foldl1 :: (a -> a -> a) -> Identity a -> a # elem :: Eq a => a -> Identity a -> Bool # maximum :: Ord a => Identity a -> a # minimum :: Ord a => Identity a -> a # | |||||
Foldable1 Identity | Since: base-4.18.0.0 | ||||
Defined in Data.Foldable1 Methods fold1 :: Semigroup m => Identity m -> m # foldMap1 :: Semigroup m => (a -> m) -> Identity a -> m # foldMap1' :: Semigroup m => (a -> m) -> Identity a -> m # toNonEmpty :: Identity a -> NonEmpty a # maximum :: Ord a => Identity a -> a # minimum :: Ord a => Identity a -> a # foldrMap1 :: (a -> b) -> (a -> b -> b) -> Identity a -> b # foldlMap1' :: (a -> b) -> (b -> a -> b) -> Identity a -> b # foldlMap1 :: (a -> b) -> (b -> a -> b) -> Identity a -> b # foldrMap1' :: (a -> b) -> (a -> b -> b) -> Identity a -> b # | |||||
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 | |||||
Show1 Identity | Since: base-4.9.0.0 | ||||
Traversable Identity | Since: base-4.9.0.0 | ||||
Applicative Identity | Since: base-4.8.0.0 | ||||
Functor Identity | Since: base-4.8.0.0 | ||||
Monad Identity | Since: base-4.8.0.0 | ||||
Generic1 Identity | |||||
Defined in Data.Functor.Identity Associated Types
| |||||
Data a => Data (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Data Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Identity a -> c (Identity a) # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Identity a) # toConstr :: Identity a -> Constr # dataTypeOf :: Identity a -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (Identity a)) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Identity a)) # gmapT :: (forall b. Data b => b -> b) -> Identity a -> Identity a # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Identity a -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Identity a -> r # gmapQ :: (forall d. Data d => d -> u) -> Identity a -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> Identity a -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Identity a -> m (Identity a) # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Identity a -> m (Identity a) # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Identity a -> m (Identity a) # | |||||
IsString a => IsString (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.String Methods fromString :: String -> Identity a # | |||||
Storable a => Storable (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods alignment :: Identity a -> Int # peekElemOff :: Ptr (Identity a) -> Int -> IO (Identity a) # pokeElemOff :: Ptr (Identity a) -> Int -> Identity a -> IO () # peekByteOff :: Ptr b -> Int -> IO (Identity a) # pokeByteOff :: Ptr b -> Int -> Identity a -> IO () # | |||||
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 Data.Functor.Identity Methods (.&.) :: Identity a -> Identity a -> Identity a # (.|.) :: Identity a -> Identity a -> Identity a # xor :: Identity a -> Identity a -> Identity a # complement :: Identity a -> Identity a # shift :: Identity a -> Int -> Identity a # rotate :: Identity a -> Int -> Identity a # setBit :: Identity a -> Int -> Identity a # clearBit :: Identity a -> Int -> Identity a # complementBit :: Identity a -> Int -> Identity a # testBit :: Identity a -> Int -> Bool # bitSizeMaybe :: Identity a -> Maybe Int # bitSize :: Identity a -> Int # isSigned :: Identity a -> Bool # shiftL :: Identity a -> Int -> Identity a # unsafeShiftL :: Identity a -> Int -> Identity a # shiftR :: Identity a -> Int -> Identity a # unsafeShiftR :: Identity a -> Int -> Identity a # rotateL :: Identity a -> Int -> Identity a # | |||||
FiniteBits a => FiniteBits (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods finiteBitSize :: Identity a -> Int # countLeadingZeros :: Identity a -> Int # countTrailingZeros :: Identity a -> Int # | |||||
Bounded a => Bounded (Identity a) | Since: base-4.9.0.0 | ||||
Enum a => Enum (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods succ :: Identity a -> Identity a # pred :: Identity a -> Identity a # fromEnum :: Identity a -> Int # enumFrom :: Identity a -> [Identity a] # enumFromThen :: Identity a -> Identity a -> [Identity a] # enumFromTo :: Identity a -> Identity a -> [Identity a] # enumFromThenTo :: Identity a -> Identity a -> Identity a -> [Identity a] # | |||||
Floating a => Floating (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods exp :: Identity a -> Identity a # log :: Identity a -> Identity a # sqrt :: Identity a -> Identity a # (**) :: Identity a -> Identity a -> Identity a # logBase :: Identity a -> Identity a -> Identity a # sin :: Identity a -> Identity a # cos :: Identity a -> Identity a # tan :: Identity a -> Identity a # asin :: Identity a -> Identity a # acos :: Identity a -> Identity a # atan :: Identity a -> Identity a # sinh :: Identity a -> Identity a # cosh :: Identity a -> Identity a # tanh :: Identity a -> Identity a # asinh :: Identity a -> Identity a # acosh :: Identity a -> Identity a # atanh :: Identity a -> Identity a # log1p :: Identity a -> Identity a # expm1 :: Identity a -> Identity a # | |||||
RealFloat a => RealFloat (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods floatRadix :: Identity a -> Integer # floatDigits :: Identity a -> Int # floatRange :: Identity a -> (Int, Int) # decodeFloat :: Identity a -> (Integer, Int) # encodeFloat :: Integer -> Int -> Identity a # exponent :: Identity a -> Int # significand :: Identity a -> Identity a # scaleFloat :: Int -> Identity a -> Identity a # isInfinite :: Identity a -> Bool # isDenormalized :: Identity a -> Bool # isNegativeZero :: Identity a -> Bool # | |||||
Generic (Identity a) | |||||
Defined in Data.Functor.Identity Associated Types
| |||||
Ix a => Ix (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods range :: (Identity a, Identity a) -> [Identity a] # index :: (Identity a, Identity a) -> Identity a -> Int # unsafeIndex :: (Identity a, Identity a) -> Identity a -> Int # inRange :: (Identity a, Identity a) -> Identity a -> Bool # rangeSize :: (Identity a, Identity a) -> Int # unsafeRangeSize :: (Identity a, Identity a) -> Int # | |||||
Num a => Num (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity | |||||
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 Data.Functor.Identity Methods quot :: Identity a -> Identity a -> Identity a # rem :: Identity a -> Identity a -> Identity a # div :: Identity a -> Identity a -> Identity a # mod :: Identity a -> Identity a -> Identity a # quotRem :: Identity a -> Identity a -> (Identity a, Identity a) # divMod :: Identity a -> Identity a -> (Identity a, Identity a) # | |||||
Real a => Real (Identity a) | Since: base-4.9.0.0 | ||||
Defined in Data.Functor.Identity Methods toRational :: Identity a -> Rational # | |||||
RealFrac a => RealFrac (Identity a) | Since: base-4.9.0.0 | ||||
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 Data.Functor.Identity | |||||
type Rep1 Identity | Since: base-4.8.0.0 | ||||
Defined in Data.Functor.Identity | |||||
type Rep (Identity a) | Since: base-4.8.0.0 | ||||
Defined in Data.Functor.Identity |
replicateM :: Applicative m => CountOf a -> m a -> m [a] Source #
performs the action replicateM
n actn
times,
gathering the results.