Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Continuation monads #700

Open
vikraman opened this issue Nov 24, 2015 · 11 comments
Open

Continuation monads #700

vikraman opened this issue Nov 24, 2015 · 11 comments

Comments

@vikraman
Copy link
Contributor

Should Cont, ContT, IndexedContT be added to cats? What would be the proper place to add them?

@erikerlandson
Copy link
Contributor

I'd like to see this

@erikerlandson
Copy link
Contributor

This blog post makes a better argument for value of continuation monads than I would have made:
http://www.haskellforall.com/2012/12/the-continuation-monad.html

continuation_kleisli

@johnynek
Copy link
Contributor

johnynek commented Oct 1, 2016

I took a stab at this:
https://gist.github.com/johnynek/cdbb988351b63be58af053b716b33106

I don't see how to make it totally stack safe. I had an idea to use threads but that seems terrible. Anyway, something like my above implementation may actually be useful because stack depth is only proportional to the number of nested continuations, not flatMaps (which are trampolined).

I played with using this for the poor man's concurrency monad, and it seems okay.

I (or anyone) could make a cats PR if we think this would be generally useful.

@erikerlandson
Copy link
Contributor

@johnynek that looks very cool! To the extent that I understand the use cases I've seen (which isn't as much as I'd like), I don't think they would manifest deep stacks.

@adelbertc
Copy link
Contributor

Would get a 👍 from me. It would also give me an opportunity to harp on about extensible effects and Cont ;)

@johnynek
Copy link
Contributor

johnynek commented Oct 4, 2016

take a look at the PR: #1400

@danslapman
Copy link
Contributor

For all, who needs continuation monad, I just ported IndexedContT from scalaz: https://github.com/danslapman/cats-conts

@bblfish
Copy link

bblfish commented Aug 22, 2019

Very cool. Reading Bartosz Milewski's Category Theory for Programmers, Scala edition I understood that continuations are essentially what the Yoneda Lemma is about. So I also looked around to get a better grip on how these tie in to practical applications. In a way it's not difficult - there are many examples of CPS in JS, etc... The tricky bit is getting to the point that it is crystal clear how the theory and practice tie together, so that one can explain it and think with it in everyday coding.

Many of the blog posts on the topic are in Haskell. The best of them was the continuation monad post referenced by @erikerlandson above. There is also The mother of all monads which I thought very helpful.
There is a whole list of examples on the Reddit discussion thread: Real world examples of the Cont Monad. Looking through that I found a video lecture in Haskell Continuation Passing Style in Haskell. There was a blog post that showed in Haskell how to build web pages, but it had functions that were so long that it really was incomprehensible.

There is the nice tutorials in Scala on continuations by @DevInsideYou (to get the full picture one should watch the previous and the next one). But from that I got the impression that the problem with continuations is that they don't really work that well in Scala because of the danger of them using up the whole stack. But I see that the second PR on this topic makes them stack safe! DevInsideYou then moves over to the
Cont class in Scala to help with recursive datatypes and then moves on to FreeMonads. So I ended up getting the impression that there is a relation between Cont and Free Monads. So I found this article that Continuation passing style Free Monads and direct style Free Monads

There is video on using continuations to build web services in Scala.

@japgolly
Copy link

japgolly commented Aug 22, 2019 via email

@diesalbla
Copy link
Contributor

diesalbla commented May 22, 2021

Good afternoon!

So, looking at the current main branch, we already have a transformer ContT and a type alias Cont, so it would seem that the changes requested or proposed by this issue have already be done. Is there anything else needed to complete the work of this issue?

If there is a desire to add the IndexedCont or indexed continuations, perhaps that can be a separate issue with a separate discussion.

@johnynek
Copy link
Contributor

Yeah I forgot to link to this from #2506

Indexed has not been done that I know of.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants