| 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 ()
- defer :: MonadManaged m => 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
| MonadFail Managed # | |
Defined in Control.Monad.Managed | |
| MonadIO Managed # | |
Defined in Control.Monad.Managed | |
| Applicative Managed # | |
| Functor Managed # | |
| Monad Managed # | |
| MonadManaged Managed # | |
Defined in Control.Monad.Managed | |
| Monoid a => Monoid (Managed a) # | |
| Semigroup a => Semigroup (Managed a) # | |
| Floating a => Floating (Managed a) # | |
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 | |
| Num a => Num (Managed a) # | |
| Fractional a => Fractional (Managed a) # | |
Defined in Control.Monad.Managed | |
class MonadIO m => MonadManaged m where #
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
| MonadManaged Managed # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (MaybeT m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (ExceptT e m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (IdentityT m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (ReaderT r m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (StateT s m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (StateT s m) # | |
Defined in Control.Monad.Managed | |
| (Monoid w, MonadManaged m) => MonadManaged (WriterT w m) # | |
Defined in Control.Monad.Managed | |
| (Monoid w, MonadManaged m) => MonadManaged (WriterT w m) # | |
Defined in Control.Monad.Managed | |
| MonadManaged m => MonadManaged (ContT r m) # | |
Defined in Control.Monad.Managed | |
| (Monoid w, MonadManaged m) => MonadManaged (RWST r w s m) # | |
Defined in Control.Monad.Managed | |
| (Monoid w, MonadManaged m) => MonadManaged (RWST r w s m) # | |
Defined in Control.Monad.Managed | |
managed :: MonadManaged m => (forall r. (a -> IO r) -> IO r) -> m a #
Build a Managed value
managed_ :: MonadManaged m => (forall r. IO r -> IO r) -> m () #
Like managed but for resource-less operations.
defer :: MonadManaged m => IO r -> m () #
Defer running an action until exit (via runManaged).
For example, the following code will print "Hello" followed by "Goodbye":
runManaged $ do defer $ liftIO $ putStrLn "Goodbye" liftIO $ putStrLn "Hello"
runManaged :: Managed () -> IO () #
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 # | |
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 | |