-
Notifications
You must be signed in to change notification settings - Fork 15
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
Make 'return' (and later 'next'/'last'/'redo') bind to the mainline, not to the quasi/macro #483
Comments
I did mean "dynamic at compile-time" (please don't make this dynamic at runtime!), I think Let Over Lambda's term of "sublexical" is applicable here. |
Same as in #159 (comment) ? |
Yes -- you have better memory than I do. |
Probably not a big deal (since various dataflow steps will have to happen after macro expansion anyway), but implementing this issue means that you can't know things statically about unexpanded source with macros in it, since any given macro might contain control-flow primitives. |
It was already (meant to be) possible before, with exceptions. |
Fair point, although (correct me if I'm wrong), if you're not doing any Again, no big deal. It just means that until we've expanded fully, we don't necessarily have the full control-flow graph. |
Suggestion via conversation with @vendethiel++, who finally convinced me this is a good idea.
Here's some code to discuss around:
According to my previously held view, the
return 42
would get injected by the mainline, but then fail at runtime because at that point the surrounding routine that bound thatreturn
(the macror42
) has already exited.This issue suggests changing the semantics so that
return 42
actually returns fromfoo
. This is done in practice byreturn
binding later, at macro expansion time. No prob, since a quasi does not contain 007 code.By the way, once we have #325, this should apply to those control-flow keywords as well.
(@vendethiel describes the above behavior as
return
being dynamic, but I don't think that's quite it. It's still a lexical binding, it's just that it's done a bit later, at macro expansion time. This is in analogy with #216 and macro calls, by the way. The whole thing can be justified, or at least hand-waved, becausereturn
is a statement form. In other words, this is a counterargument against makingreturn
a listop, as #300 suggests. (Because thenreturn
would just be a normal identifier, and there'd be no good reason for it to bind so late.))The text was updated successfully, but these errors were encountered: