mirror of
https://github.com/python/cpython.git
synced 2025-08-22 17:55:18 +00:00
gh-102832: IDLE - remove use of deprecated sys.last_xyzs for stackviewer (#103339)
This commit is contained in:
parent
68dfa49627
commit
3ee921d84f
4 changed files with 21 additions and 51 deletions
|
@ -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)
|
||||||
|
|
|
@ -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")
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue