-
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
Imperative flavour: continue & break in loops #44
Comments
On 11 Jun 2021, at 09:12, dumblob ***@***.***> wrote:
Because XL is fundamentally kind of functional, it seems uneasy to simulate continue from imperative loops.
XL is not fundamentally functional, it is fundamentally concept-oriented. This means that being able to implement a functional dialect is as important as being able to implement other dialects, but not more important.
Older more imperative-looking variants of XL had "restart" for "continue" (but I did not like that name much), see https://github.com/c3d/xl/blob/cb1d9b3fd9d18f5131c85fe5d6fcec8ec3fde3c8/xl2/native/xl.semantics.declarations.xl#L487.
I know it may seem a bit unconventional, but the parse tree that you see in these source codes is the same as what you see in the "functional" examples. See the discussions of "syntactic sugar" in the doc.
```
function NonSourceType(tp : any_type) return any_type is
result := tp
loop
stp : result as source_type
exit if stp = nil
result := stp.base
```
Could just as well be written with the shorter form
```
NonSourceType tp:any_type as any_type is ...
```
`function` here is syntactic sugar, you can add it (and you can even give it a meaning, namely "I do not expect side effects here").
Same goes for break (one could use return instead, but that'd work only without nesting I suppose which renders it completely unusable).
XL2 used "exit" for "break", with a conditional "exit if" variant, see https://github.com/c3d/xl/blob/cb1d9b3fd9d18f5131c85fe5d6fcec8ec3fde3c8/xl2/native/xl.semantics.types.xl#L263.
Any plans to provide break is builtin jmp_right_right_after_nearest_loop and continue is builtin jmp_to_the_nearest_loop_label?
Even plans to implement "goto" at some point. It's very hard to write a low-level code generator if the target language does not have "goto". All CPUs today have variants of goto (jump, branch, whatever).
Again, XL is concept-oriented. This means that I must be able to represent the concepts of functional programming with the same ease as the concepts of assembly language. Or Prolog. Or mathematics.
|
Interesting. It looks like email replies do not support markdown in GitHub. Weird. |
Just to clarify, with Btw. I didn't even know there is Anyway thanks for the |
There is much to be done. Nothing really works right now, I broke everything in my last big refactoring :-) |
Because XL is fundamentally kind of functional, it seems uneasy to simulate
continue
from imperative loops. Same goes forbreak
(one could usereturn
instead, but that'd work only without nesting I suppose which renders it completely unusable).Any plans to provide
break is builtin jmp_right_right_after_nearest_loop
andcontinue is builtin jmp_to_the_nearest_loop_label
?The text was updated successfully, but these errors were encountered: