-
Notifications
You must be signed in to change notification settings - Fork 143
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
Python version: interp_stmts has odd structure #136
Comments
The motivation is to handle Goto in the chapter for Booleans and Conditionals. (See |
I've pushed the change to the continuation passing approach. |
But why is there any need to pass continuations? If you get a chance, take a look at branch apt-stmt-experiment of python-student-support-code. I haven't made a formal pull request for it. This implements two (essentially independent) things:
Even if you don't like the second change, I think the first one is a clear win unless I'm missing something. Similar changes could be made in the type checkers, but that gets just a little hairier, and I'm not quite so worried about exposing students to (the existing form of) that code. |
The interpreter in your branch always executes all of the statements in a program.
By passing the continuation as a parameter, we give control about what happens next to each statement. So the |
Um, but isn't it the case that |
That's a good point. The grammar only has gotos in tail position. |
Hmm, it looks like I let the interpreters get out of sync with the grammars at some point. The interp_stmts function should be replaced by interp_tail. |
Doh, I was looking at the grammar in the Racket version... ok, so the Python grammar and Racket grammar for the C IR languages differ in this regard... but should they?... part of what's tricky here is that I did not introduce a C_Var language in Chapter 2, and instead L_Var plays that role. And I've set up C_If so that L_Var is a subset. But that doesn't need to be the case. Yes, it would be good for my own sanity to get the Python version of C_If in sync with the Racket one. |
I've updated the grammars and interpreters for the C languages (C_If, etc.) but for now I'm leaving the continuation parameter for the L languages as the way to handle early return. While there are other ways to handle the early return, the nice thing about the continuation approach in the interpreter is that it jives with the structure of explicate_control. |
In Figure 2.3/2.4 (and subsequent chapters),
interp_stmts
does a deep match on individual statement kinds, rather than simply iterating over the list and invoking a separateinterp_stmt
function. This violates the code structuring principle noted on p. 7 footnote1 . Moreover, it is quite unclear why this function returns the result of the recursive invocation on the tail (ultimately it always returns None).The motivation for both these things is presumably to handle
return
starting in Ch. 8, but meanwhile they are quite mysterious, and set a poor example for students who will be looking at this code for guidance on how to write recursive functions and usingmatch
statements.And on that point, even if this is kept as a deep match, why not write it
using a
match
statement rather than testing (inefficiently in the super calls) separately forlen(ss) == 0
??The text was updated successfully, but these errors were encountered: