gh-102832: IDLE - remove use of deprecated sys.last_xyzs for stackviewer (#103339)

This commit is contained in:
Irit Katriel 2023-06-08 21:19:05 +01:00 committed by GitHub
parent 68dfa49627
commit 3ee921d84f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 21 additions and 51 deletions

View file

@ -6,19 +6,12 @@ from test.support import requires
from tkinter import Tk from tkinter import Tk
from idlelib.tree import TreeNode, ScrolledCanvas from idlelib.tree import TreeNode, ScrolledCanvas
import sys
class StackBrowserTest(unittest.TestCase): class StackBrowserTest(unittest.TestCase):
@classmethod @classmethod
def setUpClass(cls): def setUpClass(cls):
svs = stackviewer.sys
try:
abc
except NameError:
svs.last_type, svs.last_value, svs.last_traceback = (
sys.exc_info())
requires('gui') requires('gui')
cls.root = Tk() cls.root = Tk()
@ -26,8 +19,6 @@ class StackBrowserTest(unittest.TestCase):
@classmethod @classmethod
def tearDownClass(cls): def tearDownClass(cls):
svs = stackviewer.sys
del svs.last_traceback, svs.last_type, svs.last_value
cls.root.update_idletasks() cls.root.update_idletasks()
## for id in cls.root.tk.call('after', 'info'): ## for id in cls.root.tk.call('after', 'info'):
@ -36,7 +27,10 @@ class StackBrowserTest(unittest.TestCase):
del cls.root del cls.root
def test_init(self): def test_init(self):
sb = stackviewer.StackBrowser(self.root) try:
abc
except NameError as exc:
sb = stackviewer.StackBrowser(self.root, exc)
isi = self.assertIsInstance isi = self.assertIsInstance
isi(stackviewer.sc, ScrolledCanvas) isi(stackviewer.sc, ScrolledCanvas)
isi(stackviewer.item, stackviewer.StackTreeItem) isi(stackviewer.item, stackviewer.StackTreeItem)

View file

@ -1363,19 +1363,19 @@ class PyShell(OutputWindow):
self.text.tag_remove(self.user_input_insert_tags, index_before) self.text.tag_remove(self.user_input_insert_tags, index_before)
self.shell_sidebar.update_sidebar() self.shell_sidebar.update_sidebar()
def open_stack_viewer(self, event=None): def open_stack_viewer(self, event=None): # -n mode only
if self.interp.rpcclt: if self.interp.rpcclt:
return self.interp.remote_stack_viewer() return self.interp.remote_stack_viewer()
from idlelib.stackviewer import StackBrowser
try: try:
sys.last_traceback StackBrowser(self.root, sys.last_value, self.flist)
except: except:
messagebox.showerror("No stack trace", messagebox.showerror("No stack trace",
"There is no stack trace yet.\n" "There is no stack trace yet.\n"
"(sys.last_traceback is not defined)", "(sys.last_value is not defined)",
parent=self.text) parent=self.text)
return return None
from idlelib.stackviewer import StackBrowser
StackBrowser(self.root, self.flist)
def view_restart_mark(self, event=None): def view_restart_mark(self, event=None):
self.text.see("iomark") self.text.see("iomark")

View file

@ -622,7 +622,7 @@ class Executive:
def stackviewer(self, flist_oid=None): def stackviewer(self, flist_oid=None):
if self.user_exc_info: if self.user_exc_info:
typ, val, tb = self.user_exc_info _, exc, tb = self.user_exc_info
else: else:
return None return None
flist = None flist = None
@ -630,9 +630,8 @@ class Executive:
flist = self.rpchandler.get_remote_proxy(flist_oid) flist = self.rpchandler.get_remote_proxy(flist_oid)
while tb and tb.tb_frame.f_globals["__name__"] in ["rpc", "run"]: while tb and tb.tb_frame.f_globals["__name__"] in ["rpc", "run"]:
tb = tb.tb_next tb = tb.tb_next
sys.last_type = typ exc.__traceback__ = tb
sys.last_value = val item = stackviewer.StackTreeItem(exc, flist)
item = stackviewer.StackTreeItem(flist, tb)
return debugobj_r.remote_object_tree_item(item) return debugobj_r.remote_object_tree_item(item)

View file

@ -1,33 +1,30 @@
import linecache import linecache
import os import os
import sys
import tkinter as tk import tkinter as tk
from idlelib.debugobj import ObjectTreeItem, make_objecttreeitem from idlelib.debugobj import ObjectTreeItem, make_objecttreeitem
from idlelib.tree import TreeNode, TreeItem, ScrolledCanvas from idlelib.tree import TreeNode, TreeItem, ScrolledCanvas
def StackBrowser(root, flist=None, tb=None, top=None): def StackBrowser(root, exc, flist=None, top=None):
global sc, item, node # For testing. global sc, item, node # For testing.
if top is None: if top is None:
top = tk.Toplevel(root) top = tk.Toplevel(root)
sc = ScrolledCanvas(top, bg="white", highlightthickness=0) sc = ScrolledCanvas(top, bg="white", highlightthickness=0)
sc.frame.pack(expand=1, fill="both") sc.frame.pack(expand=1, fill="both")
item = StackTreeItem(flist, tb) item = StackTreeItem(exc, flist)
node = TreeNode(sc.canvas, None, item) node = TreeNode(sc.canvas, None, item)
node.expand() node.expand()
class StackTreeItem(TreeItem): class StackTreeItem(TreeItem):
def __init__(self, flist=None, tb=None): def __init__(self, exc, flist=None):
self.flist = flist self.flist = flist
self.stack = self.get_stack(tb) self.stack = self.get_stack(None if exc is None else exc.__traceback__)
self.text = self.get_exception() self.text = f"{type(exc).__name__}: {str(exc)}"
def get_stack(self, tb): def get_stack(self, tb):
if tb is None:
tb = sys.last_traceback
stack = [] stack = []
if tb and tb.tb_frame is None: if tb and tb.tb_frame is None:
tb = tb.tb_next tb = tb.tb_next
@ -36,17 +33,7 @@ class StackTreeItem(TreeItem):
tb = tb.tb_next tb = tb.tb_next
return stack return stack
def get_exception(self): def GetText(self): # Titlecase names are overrides.
type = sys.last_type
value = sys.last_value
if hasattr(type, "__name__"):
type = type.__name__
s = str(type)
if value is not None:
s = s + ": " + str(value)
return s
def GetText(self):
return self.text return self.text
def GetSubList(self): def GetSubList(self):
@ -133,19 +120,9 @@ def _stack_viewer(parent): # htest #
flist = PyShellFileList(top) flist = PyShellFileList(top)
try: # to obtain a traceback object try: # to obtain a traceback object
intentional_name_error intentional_name_error
except NameError: except NameError as e:
exc_type, exc_value, exc_tb = sys.exc_info() StackBrowser(top, e, flist=flist, top=top)
# inject stack trace to sys
sys.last_type = exc_type
sys.last_value = exc_value
sys.last_traceback = exc_tb
StackBrowser(top, flist=flist, top=top, tb=exc_tb)
# restore sys to original state
del sys.last_type
del sys.last_value
del sys.last_traceback
if __name__ == '__main__': if __name__ == '__main__':
from unittest import main from unittest import main