| Safe Haskell | None | 
|---|---|
| Language | Haskell98 | 
Control.Monad.Chronicle.Class
Description
Hybrid error/writer monad class that allows both accumulating outputs and aborting computation with a final output.
The expected use case is for computations with a notion of fatal vs. non-fatal errors.
- class Monad m => MonadChronicle c m | m -> c where
- newtype ChronicleT c m a = ChronicleT {- runChronicleT :: m (These c a)
 
- runChronicle :: Chronicle c a -> These c a
Documentation
class Monad m => MonadChronicle c m | m -> c where Source #
Methods
disclose :: Default a => c -> m a Source #
disclose cc and returns a
   Default
This is a convenience function for reporting non-fatal errors in one
   branch a case, or similar scenarios when there is no meaningful 
   result but a placeholder of sorts is needed in order to continue.
confess cc.
Equivalent to throwError for the Error monad.
memento :: m a -> m (Either c a) Source #
memento mm, returning either
   its record if it ended with confess, or its final value otherwise, with
   any record added to the current record.
Similar to catchError in the Error monad, but with a notion of 
   non-fatal errors (which are accumulated) vs. fatal errors (which are caught
   without accumulating).
absolve :: a -> m a -> m a Source #
absolve x mm and discards any
   record it had. The default value x will be used if m ended via 
   confess.
condemn :: m a -> m a Source #
condemn mm and keeps its value
   only if it had no record. Otherwise, the value (if any) will be discarded
   and only the record kept.
This can be seen as converting non-fatal errors into fatal ones.
retcon :: (c -> c) -> m a -> m a Source #
retcon f mm and applies the
   function f to its output, leaving the return value unchanged.
chronicle :: These c a -> m a Source #
chronicle mMonadChronicle instance.
Instances
| MonadChronicle c m => MonadChronicle c (MaybeT m) Source # | |
| Semigroup c => MonadChronicle c (These c) Source # | |
| (Monoid w, MonadChronicle c m) => MonadChronicle c (WriterT w m) Source # | |
| (Monoid w, MonadChronicle c m) => MonadChronicle c (WriterT w m) Source # | |
| MonadChronicle c m => MonadChronicle c (StateT s m) Source # | |
| MonadChronicle c m => MonadChronicle c (StateT s m) Source # | |
| MonadChronicle c m => MonadChronicle c (ExceptT e m) Source # | |
| (Error e, MonadChronicle c m) => MonadChronicle c (ErrorT e m) Source # | |
| MonadChronicle c m => MonadChronicle c (IdentityT * m) Source # | |
| (Semigroup c, Monad m) => MonadChronicle c (ChronicleT c m) Source # | |
| MonadChronicle c m => MonadChronicle c (ReaderT * r m) Source # | |
| (Monoid w, MonadChronicle c m) => MonadChronicle c (RWST r w s m) Source # | |
| (Monoid w, MonadChronicle c m) => MonadChronicle c (RWST r w s m) Source # | |
newtype ChronicleT c m a Source #
The ChronicleT monad transformer.
The return function produces a computation with no output, and >>=
   combines multiple outputs with mappend.
Constructors
| ChronicleT | |
| Fields 
 | |
Instances
runChronicle :: Chronicle c a -> These c a Source #