Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Control.Monad.Managed.Safe
Contents
Description
This module is a safer subset of Control.Monad.Managed that only lets you
unwrap the Managed
type using runManaged
. This enforces that you never
leak acquired resources from a Managed
computation.
In general, you should strive to propagate the Managed
type as much as
possible and use runManaged
when you are done with acquired resources.
However, there are legitimate circumstances where you want to return a value
other than acquired resource from the bracketed computation, which requires
using with
.
This module is not the default because you can also use the Managed
type
for callback-based code that is completely unrelated to resources.
Synopsis
- data Managed a
- class MonadIO m => MonadManaged m where
- managed :: MonadManaged m => (forall r. (a -> IO r) -> IO r) -> m a
- managed_ :: MonadManaged m => (forall r. IO r -> IO r) -> m ()
- runManaged :: Managed () -> IO ()
- class Monad m => MonadIO (m :: Type -> Type) where
- liftIO :: IO a -> m a
Managed
A managed resource that you acquire using with
Instances
Monad Managed Source # | |
Functor Managed Source # | |
MonadFail Managed Source # | |
Defined in Control.Monad.Managed | |
Applicative Managed Source # | |
MonadIO Managed Source # | |
Defined in Control.Monad.Managed | |
MonadManaged Managed Source # | |
Floating a => Floating (Managed a) Source # | |
Defined in Control.Monad.Managed Methods sqrt :: Managed a -> Managed a (**) :: Managed a -> Managed a -> Managed a logBase :: Managed a -> Managed a -> Managed a asin :: Managed a -> Managed a acos :: Managed a -> Managed a atan :: Managed a -> Managed a sinh :: Managed a -> Managed a cosh :: Managed a -> Managed a tanh :: Managed a -> Managed a asinh :: Managed a -> Managed a acosh :: Managed a -> Managed a atanh :: Managed a -> Managed a log1p :: Managed a -> Managed a expm1 :: Managed a -> Managed a | |
Fractional a => Fractional (Managed a) Source # | |
Defined in Control.Monad.Managed | |
Num a => Num (Managed a) Source # | |
Semigroup a => Semigroup (Managed a) Source # | |
Monoid a => Monoid (Managed a) Source # | |
class MonadIO m => MonadManaged m where Source #
You can embed a Managed
action within any Monad
that implements
MonadManaged
by using the using
function
All instances must obey the following two laws:
using (return x) = return x using (m >>= f) = using m >>= \x -> using (f x)
Instances
managed :: MonadManaged m => (forall r. (a -> IO r) -> IO r) -> m a Source #
Build a Managed
value
managed_ :: MonadManaged m => (forall r. IO r -> IO r) -> m () Source #
Like managed
but for resource-less operations.
runManaged :: Managed () -> IO () Source #
Run a Managed
computation, enforcing that no acquired resources leak
Re-exports
Control.Monad.IO.Class re-exports MonadIO
class Monad m => MonadIO (m :: Type -> Type) where #
Instances
MonadIO IO | |
Defined in Control.Monad.IO.Class | |
MonadIO Managed Source # | |
Defined in Control.Monad.Managed | |
MonadIO m => MonadIO (MaybeT m) | |
Defined in Control.Monad.Trans.Maybe | |
MonadIO m => MonadIO (ExceptT e m) | |
Defined in Control.Monad.Trans.Except | |
MonadIO m => MonadIO (IdentityT m) | |
Defined in Control.Monad.Trans.Identity | |
MonadIO m => MonadIO (ReaderT r m) | |
Defined in Control.Monad.Trans.Reader | |
MonadIO m => MonadIO (StateT s m) | |
Defined in Control.Monad.Trans.State.Lazy | |
MonadIO m => MonadIO (StateT s m) | |
Defined in Control.Monad.Trans.State.Strict | |
(Monoid w, MonadIO m) => MonadIO (WriterT w m) | |
Defined in Control.Monad.Trans.Writer.Lazy | |
(Monoid w, MonadIO m) => MonadIO (WriterT w m) | |
Defined in Control.Monad.Trans.Writer.Strict | |
MonadIO m => MonadIO (ContT r m) | |
Defined in Control.Monad.Trans.Cont | |
(Monoid w, MonadIO m) => MonadIO (RWST r w s m) | |
Defined in Control.Monad.Trans.RWS.Lazy | |
(Monoid w, MonadIO m) => MonadIO (RWST r w s m) | |
Defined in Control.Monad.Trans.RWS.Strict |