module Sound.MIDI.Parser.Warning where
import qualified Sound.MIDI.Parser.Report as Report
import qualified Control.Monad.Exception.Synchronous as Sync
import qualified Control.Monad.Trans.Writer as Writer
type T m = Writer.WriterT [Report.UserMessage] m
run :: Monad m =>
T m (Sync.Exceptional Report.UserMessage a) -> m (Report.T a)
run :: T m (Exceptional UserMessage a) -> m (T a)
run T m (Exceptional UserMessage a)
act =
do (Exceptional UserMessage a
exc,[UserMessage]
warns) <- T m (Exceptional UserMessage a)
-> m (Exceptional UserMessage a, [UserMessage])
forall w (m :: * -> *) a. WriterT w m a -> m (a, w)
Writer.runWriterT T m (Exceptional UserMessage a)
act
T a -> m (T a)
forall (m :: * -> *) a. Monad m => a -> m a
return (T a -> m (T a)) -> T a -> m (T a)
forall a b. (a -> b) -> a -> b
$ [UserMessage] -> Either UserMessage a -> T a
forall a. [UserMessage] -> Either UserMessage a -> T a
Report.Cons [UserMessage]
warns (Exceptional UserMessage a -> Either UserMessage a
forall e a. Exceptional e a -> Either e a
Sync.toEither Exceptional UserMessage a
exc)
warn :: Monad m => String -> T m ()
warn :: UserMessage -> T m ()
warn UserMessage
text = [UserMessage] -> T m ()
forall (m :: * -> *) w. Monad m => w -> WriterT w m ()
Writer.tell [UserMessage
text]