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

limitations of new multiline code and closure support in pdb #126958

Open
limwz01 opened this issue Nov 18, 2024 · 2 comments
Open

limitations of new multiline code and closure support in pdb #126958

limwz01 opened this issue Nov 18, 2024 · 2 comments
Assignees
Labels
type-bug An unexpected behavior, bug, or error

Comments

@limwz01
Copy link

limwz01 commented Nov 18, 2024

Bug report

Bug description:

The following code is the template to illustrate the problems:

#!/usr/bin/env python3.13
g0 = 0
def main():
    import pdb
    pdb.Pdb().set_trace()
if __name__ == "__main__":
    main()

The problems:

  • not re-using the same Cells for each local (this is really the biggest issue)
(Pdb) t = 1
(Pdb) f = lambda: t
(Pdb) t = 2
(Pdb) f()
1
  • not obtaining the last expression (a pdb test suggests otherwise, but it is actually wrong)
(Pdb) t=10; (lambda: t)()
<no output>

(it does return a value for global g; g=1; g. but I'm at a loss as to where that value comes from)

  • giving a weird result with shadowed variables (actually because it bails out):
(Pdb) g0 = 1
(Pdb) global g0; t=g0; t=(lambda: t)()
*** NameError: name 't' is not defined
  • not removing annotations (not allowed for nonlocal variables)
(Pdb) t:int = 1; (lambda: t)()
*** NameError: name 't' is not defined
  • using indentation to set up block scope
(Pdb) print((lambda:len("""
... """))())
7
  • not remembering globals (this is arguable):
(Pdb) global g; g=1
(Pdb) t=2
(Pdb) g=(lambda: t)()
(Pdb) global g; g
1

@gaogaotiantian

CPython versions tested on:

3.13

Operating systems tested on:

Linux

@limwz01 limwz01 added the type-bug An unexpected behavior, bug, or error label Nov 18, 2024
@limwz01
Copy link
Author

limwz01 commented Nov 18, 2024

An approach similar to mine at https://github.com/limwz01/ipython_utils and published at https://pypi.org/project/ipython-utils/ might help here. My code is very complicated but that's also because I wanted to support dynamic reloading of the code after an exception.

@gaogaotiantian gaogaotiantian self-assigned this Nov 18, 2024
@gaogaotiantian
Copy link
Member

Thank you for the detailed report and the many test cases. Like I said in the other issue, we might not be able to fix all of them, but I'll see if there's something cheap and readable thing I can do to fix some of these!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type-bug An unexpected behavior, bug, or error
Projects
None yet
Development

No branches or pull requests

2 participants