<div dir="ltr">I sympathize. If you feel the need for those combinators, you can talk to Ross to try to get him to add them to the library. (Well, secondEitherT is already fmap, of course.) When the ExceptT API was crafted, it pretty much tried to follow the API of the rest of transformers, and didn't really take any of the extra combinators we had in the either package into account. =/<div><br></div><div>You might have a hard time getting the last one adopted, though, due to the dependency on exceptions taking the API into "non-standard" territory.</div><div><br></div><div>Unfortunately, even if Ross adds them, I have no way to supply them in transformers-compat when used with middle versions of transformers that have ExceptT, but not those combinators, so the compatibility hack I offer will suffer a bit.<br><div><br></div><div>-Edward</div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Jan 2, 2017 at 2:14 AM, Erik de Castro Lopo <span dir="ltr"><<a href="mailto:mle+hs@mega-nerd.com" target="_blank">mle+hs@mega-nerd.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">Edward Kmett wrote:<br>
<br>
> Indeed. A proper "EitherT" was added, but due to bikeshedding turned into<br>
> ExceptT in the process complicating the migration story a fair bit. To get<br>
> a version of ExceptT for older transformers versions you can use<br>
> transformers-compat, so there is at least some migration story. =/<br>
<br>
</span>Thanks Ed.<br>
<br>
I'm really only interested in GHC 7.10 and later, but there are a number of<br>
combinators in Control.Monad.Trans.Either that seem to be missing from<br>
Control.Monad.Trans.Except and in my day job we have a extended version of<br>
Control.Monad.Trans.Either that has yet more combinators that I miss whenever<br>
I write code outside the work environment.<br>
<br>
Combinators in C.M.T.Either but not in C.M.T.Except:<br>
<br>
bimapEitherT :: Functor m => (e -> f) -> (a -> b) -> EitherT e m a -> EitherT f m b<br>
<br>
-- really just an alias for EitherT constructor<br>
hoistEither :: Monad m => Either e a -> EitherT e m a<br>
<br>
Combinators which I am used to using at work include:<br>
<br>
firstEitherT :: Functor m => (x -> y) -> EitherT x m a -> EitherT y m a<br>
<br>
secondEitherT :: Functor m => (a -> b) -> EitherT e m a -> EitherT e m b<br>
<br>
tryEitherT :: (Functor m, MonadCatch m, Exception e) => (e -> x) -> m a -> EitherT x m a<br>
<br>
There are probably others which I can't remember just now.<br>
<br>
Whats the right place for these, the C.M.T.Except or somewhere else? I'd<br>
prefer not to have to carry them from project to project.<br>
<div class="HOEnZb"><div class="h5"><br>
Erik<br>
--<br>
------------------------------<wbr>------------------------------<wbr>----------<br>
Erik de Castro Lopo<br>
<a href="http://www.mega-nerd.com/" rel="noreferrer" target="_blank">http://www.mega-nerd.com/</a><br>
______________________________<wbr>_________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-<wbr>bin/mailman/listinfo/libraries</a><br>
</div></div></blockquote></div><br></div>