- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.2k
bpo-33387: Simplify bytecodes for try-finally, try-except and with blocks. #6641
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
bpo-33387: Simplify bytecodes for try-finally, try-except and with blocks. #6641
Conversation
| For the record, here is the result of pyperformance.  | 
0dfe44c    to
    d8b54c9      
    Compare
  
    | @markshannon FYI,  | 
d8b54c9    to
    3efb201      
    Compare
  
    3efb201    to
    b16b8e8      
    Compare
  
    | All comments addressed and rebased to fix merge conflict with ddd1949 | 
b16b8e8    to
    d64244b      
    Compare
  
    | Rebased again | 
d64244b    to
    6f916e9      
    Compare
  
    | Rebased yet again. | 
b9c698e    to
    cdb2581      
    Compare
  
    | Rebased yet again (twice) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mostly stylistic stuff and requests for comments to help explain the code in some spots.
        
          
                Doc/library/dis.rst
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This was initially misleading to me as my brain thought of sys.exit() instead of context_manager.__exit__().
| Used to implement the call ``exit(*exc_info())`` when an exception | |
| Used to implement the call ``context_manager.__exit__(*exc_info())`` when an exception | 
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps a comment as to why some fields don't require resetting while others do? And maybe why the fields in init_codetracker() differ from those in reset()? Basically my brain is wondering why e.g. start_line is initialized but not reset, and vice-versa.
There's also a naming discrepancy between reset() and init_codetracker() in that one includes codetracker and the other does not.
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| tracker->line_addr = tracker->line_addr + tracker->lnotab[tracker->offset]; | |
| tracker->line_addr += tracker->lnotab[tracker->offset]; | 
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would expect to find this value in opcode.h but I'm not, so why the new definition of an opcode here? (A comment would be enough for me to clarify why this is here.)
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| // Skip over duplicate finally blocks if line is after body. | |
| // Skip over duplicate 'finally' blocks if line is after body. | 
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| /* Validate change of block stack */ | |
| /* Validate change of block stack. */ | 
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| /* Check for illegal jumps out of finally or except blocks */ | |
| /* Check for illegal jumps out of finally or except blocks. */ | 
        
          
                Objects/frameobject.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| /* Unwind block stack */ | |
| /* Unwind block stack. */ | 
        
          
                Python/compile.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you're up for it, would you mind fixing these if blocks to use {}? Otherwise the style is shifting and I would rather promote the new style than the old one.
        
          
                Python/compile.c
              
                Outdated
          
        
      There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| /* End of body; start the cleanup */ | |
| /* End of body; start the cleanup. */ | 
| All review comments addressed. | 
| FYI no need to wait on me on an approving review. | 
db08c6d    to
    c611d1b      
    Compare
  
    | Rebased yet again... Time to press that merge button ⬇️ 🙂 | 
| @markshannon is there anything preventing you from doing the merge at this point? | 
c611d1b    to
    1bd40b8      
    Compare
  
    | @brettcannon No technical obstacles, but I think that for large PRs like this one, it is best if someone other than the author does the merge. | 
| @markshannon Are you choosing to skip my doc change suggestions? (I'm asking because you said all the comments were addressed but those were left open/unresolved, so I just wanted to check the PR is in its final state sans merge conflict.) As for clicking "approved" on a review, that's as close as people typically get for approval on a core dev's PR. Historically core devs have done their own merges as they will be the ones to handle reversions, etc. IOW if you want to address my remaining doc comments and are willing to handle reversion duties, etc., then I can click the merge button for you. | 
1bd40b8    to
    385b2df      
    Compare
  
    54f381c    to
    23cfe89      
    Compare
  
    23cfe89    to
    62a3625      
    Compare
  
    62a3625    to
    8457a00      
    Compare
  
    …parate code for normal and exceptional paths. Remove BEGIN_FINALLY, END_FINALLY, CALL_FINALLY and POP_FINALLY bytecodes. Implement finally blocks by code duplication. Reimplement frame.lineno setter using line numbers rather than bytecode offsets.
8457a00    to
    6364ee7      
    Compare
  
    | I've been holding off on this as I wanted to let the 3.8 release stabilize before changing the bytecode. @brettcannon I have addressed all your comments. | 
| @markshannon: Please replace  | 
…parate code for normal and exceptional paths. (python#6641) Remove BEGIN_FINALLY, END_FINALLY, CALL_FINALLY and POP_FINALLY bytecodes. Implement finally blocks by code duplication. Reimplement frame.lineno setter using line numbers rather than bytecode offsets.
…parate code for normal and exceptional paths. (python#6641) Remove BEGIN_FINALLY, END_FINALLY, CALL_FINALLY and POP_FINALLY bytecodes. Implement finally blocks by code duplication. Reimplement frame.lineno setter using line numbers rather than bytecode offsets.
Quoting the bpo issue:
The implementation of
withstatements is a bit more complex. The with statementis implemented as:
https://bugs.python.org/issue33387