[Haskell-cafe] How do I do conditional tail recursion in a monad?
Jules Bean
jules at jellybean.co.uk
Wed Mar 21 08:40:45 EDT 2007
David F. Place wrote:
> So, the next question is: Why isn't this already in Control.Monad?
Some people have proposed it.
Part of the reason is all the possible variations (monadic action,
monadic test, monadic filter, etc etc), and it's all really very easy to
write yourself.
Perhaps it's even *enlightening* to write it yourself sometimes, since
it gives you practice in writing monadic code and understanding these
points :)
Maybe another part of the reason is that supplying people with a fixed
list of 'imperative-style' combinators makes them think that that's all
there is, and struggle when they need something more complex because
they aren't really sure how to use the 'lower-level' building blocks.
Still, I think there is still room for someone to suggest a really
top-notch list of 'imperative-style-monadic' combinators.
Jules
More information about the Haskell-Cafe
mailing list