Skip to content

Commit ccccf31

Browse files
authored
bpo-30495: IDLE: Modernize textview.py with docstrings and PEP8 names (#1839) (#2102)
Patch by Cheryl Sabella. (cherry picked from commit 0aa0a06)
1 parent c0ef607 commit ccccf31

File tree

3 files changed

+62
-42
lines changed

3 files changed

+62
-42
lines changed

Lib/idlelib/idle_test/test_help_about.py

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -45,10 +45,10 @@ def test_printer_buttons(self):
4545
button.invoke()
4646
self.assertEqual(
4747
printer._Printer__lines[0],
48-
dialog._current_textview.textView.get('1.0', '1.end'))
48+
dialog._current_textview.text.get('1.0', '1.end'))
4949
self.assertEqual(
5050
printer._Printer__lines[1],
51-
dialog._current_textview.textView.get('2.0', '2.end'))
51+
dialog._current_textview.text.get('2.0', '2.end'))
5252
dialog._current_textview.destroy()
5353

5454
def test_file_buttons(self):
@@ -64,10 +64,11 @@ def test_file_buttons(self):
6464
with open(fn) as f:
6565
self.assertEqual(
6666
f.readline().strip(),
67-
dialog._current_textview.textView.get('1.0', '1.end'))
67+
dialog._current_textview.text.get('1.0', '1.end'))
6868
f.readline()
69-
self.assertEqual(f.readline().strip(),
70-
dialog._current_textview.textView.get('3.0', '3.end'))
69+
self.assertEqual(
70+
f.readline().strip(),
71+
dialog._current_textview.text.get('3.0', '3.end'))
7172
dialog._current_textview.destroy()
7273

7374

Lib/idlelib/idle_test/test_textview.py

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -41,7 +41,7 @@ class TV(tv.TextViewer): # Used in TextViewTest.
4141

4242
# Call wrapper class with mock wait_window.
4343
class TextViewTest(unittest.TestCase):
44-
44+
4545
def setUp(self):
4646
TV.transient.__init__()
4747
TV.grab_set.__init__()
@@ -52,19 +52,19 @@ def test_init_modal(self):
5252
self.assertTrue(TV.transient.called)
5353
self.assertTrue(TV.grab_set.called)
5454
self.assertTrue(TV.wait_window.called)
55-
view.Ok()
55+
view.ok()
5656

5757
def test_init_nonmodal(self):
5858
view = TV(root, 'Title', 'test text', modal=False)
5959
self.assertFalse(TV.transient.called)
6060
self.assertFalse(TV.grab_set.called)
6161
self.assertFalse(TV.wait_window.called)
62-
view.Ok()
62+
view.ok()
6363

6464
def test_ok(self):
6565
view = TV(root, 'Title', 'test text', modal=False)
6666
view.destroy = Func()
67-
view.Ok()
67+
view.ok()
6868
self.assertTrue(view.destroy.called)
6969
del view.destroy # Unmask real function.
7070
view.destroy()
@@ -86,13 +86,13 @@ def tearDownClass(cls):
8686
def test_view_text(self):
8787
view = tv.view_text(root, 'Title', 'test text', modal=False)
8888
self.assertIsInstance(view, tv.TextViewer)
89-
view.Ok()
89+
view.ok()
9090

9191
def test_view_file(self):
9292
view = tv.view_file(root, 'Title', __file__, modal=False)
9393
self.assertIsInstance(view, tv.TextViewer)
94-
self.assertIn('Test', view.textView.get('1.0', '1.end'))
95-
view.Ok()
94+
self.assertIn('Test', view.text.get('1.0', '1.end'))
95+
view.ok()
9696

9797
def test_bad_file(self):
9898
# Mock showerror will be used; view_file will return None.
@@ -131,7 +131,7 @@ def _command():
131131

132132
self.assertEqual(self.called, True)
133133
self.assertEqual(self.view.title(), 'TITLE_TEXT')
134-
self.assertEqual(self.view.textView.get('1.0', '1.end'), 'COMMAND')
134+
self.assertEqual(self.view.text.get('1.0', '1.end'), 'COMMAND')
135135

136136
def test_view_file_bind_with_button(self):
137137
def _command():
@@ -144,10 +144,10 @@ def _command():
144144
self.assertEqual(self.called, True)
145145
self.assertEqual(self.view.title(), 'TITLE_FILE')
146146
with open(__file__) as f:
147-
self.assertEqual(self.view.textView.get('1.0', '1.end'),
147+
self.assertEqual(self.view.text.get('1.0', '1.end'),
148148
f.readline().strip())
149149
f.readline()
150-
self.assertEqual(self.view.textView.get('3.0', '3.end'),
150+
self.assertEqual(self.view.text.get('3.0', '3.end'),
151151
f.readline().strip())
152152

153153

Lib/idlelib/textview.py

Lines changed: 46 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,9 @@
11
"""Simple text browser for IDLE
22
33
"""
4-
from tkinter import *
4+
from tkinter import Toplevel, Frame, Button, Text
5+
from tkinter import DISABLED, SUNKEN, VERTICAL, WORD
6+
from tkinter import RIGHT, LEFT, TOP, BOTTOM, BOTH, X, Y
57
from tkinter.ttk import Scrollbar
68
from tkinter.messagebox import showerror
79

@@ -16,6 +18,9 @@ def __init__(self, parent, title, text, modal=True,
1618
If modal is left True, users cannot interact with other windows
1719
until the textview window is closed.
1820
21+
parent - parent of this dialog
22+
title - string which is title of popup dialog
23+
text - text to display in dialog
1924
_htest - bool; change box location when running htest.
2025
_utest - bool; don't wait_window when running unittest.
2126
"""
@@ -29,51 +34,65 @@ def __init__(self, parent, title, text, modal=True,
2934
self.bg = '#ffffff'
3035
self.fg = '#000000'
3136

32-
self.CreateWidgets()
37+
self.create_widgets()
3338
self.title(title)
34-
self.protocol("WM_DELETE_WINDOW", self.Ok)
39+
self.protocol("WM_DELETE_WINDOW", self.ok)
3540
self.parent = parent
36-
self.textView.focus_set()
41+
self.text.focus_set()
3742
# Bind keys for closing this dialog.
38-
self.bind('<Return>',self.Ok)
39-
self.bind('<Escape>',self.Ok)
40-
self.textView.insert(0.0, text)
41-
self.textView.config(state=DISABLED)
43+
self.bind('<Return>', self.ok)
44+
self.bind('<Escape>', self.ok)
45+
self.text.insert(0.0, text)
46+
self.text.config(state=DISABLED)
4247

4348
if modal:
4449
self.transient(parent)
4550
self.grab_set()
4651
if not _utest:
4752
self.wait_window()
4853

49-
def CreateWidgets(self):
54+
def create_widgets(self):
5055
"Create Frame with Text (with vertical Scrollbar) and Button."
51-
frameText = Frame(self, relief=SUNKEN, height=700)
52-
frameButtons = Frame(self)
53-
self.buttonOk = Button(frameButtons, text='Close',
54-
command=self.Ok, takefocus=FALSE)
55-
self.scrollbarView = Scrollbar(frameText, orient=VERTICAL,
56-
takefocus=FALSE)
57-
self.textView = Text(frameText, wrap=WORD, highlightthickness=0,
56+
frame = Frame(self, relief=SUNKEN, height=700)
57+
frame_buttons = Frame(self)
58+
self.button_ok = Button(frame_buttons, text='Close',
59+
command=self.ok, takefocus=False)
60+
self.scrollbar = Scrollbar(frame, orient=VERTICAL, takefocus=False)
61+
self.text = Text(frame, wrap=WORD, highlightthickness=0,
5862
fg=self.fg, bg=self.bg)
59-
self.scrollbarView.config(command=self.textView.yview)
60-
self.textView.config(yscrollcommand=self.scrollbarView.set)
61-
self.buttonOk.pack()
62-
self.scrollbarView.pack(side=RIGHT,fill=Y)
63-
self.textView.pack(side=LEFT,expand=TRUE,fill=BOTH)
64-
frameButtons.pack(side=BOTTOM,fill=X)
65-
frameText.pack(side=TOP,expand=TRUE,fill=BOTH)
66-
67-
def Ok(self, event=None):
63+
self.scrollbar.config(command=self.text.yview)
64+
self.text.config(yscrollcommand=self.scrollbar.set)
65+
66+
self.button_ok.pack()
67+
self.scrollbar.pack(side=RIGHT, fill=Y)
68+
self.text.pack(side=LEFT, expand=True, fill=BOTH)
69+
frame_buttons.pack(side=BOTTOM, fill=X)
70+
frame.pack(side=TOP, expand=True, fill=BOTH)
71+
72+
def ok(self, event=None):
73+
"""Dismiss text viewer dialog."""
6874
self.destroy()
6975

7076

7177
def view_text(parent, title, text, modal=True, _utest=False):
72-
"Display text in a TextViewer."
78+
"""Create TextViewer for given text.
79+
80+
parent - parent of this dialog
81+
title - string which is the title of popup dialog
82+
text - text to display in this dialog
83+
modal - controls if users can interact with other windows while this
84+
dialog is displayed
85+
_utest - bool; controls wait_window on unittest
86+
"""
7387
return TextViewer(parent, title, text, modal, _utest=_utest)
7488

89+
7590
def view_file(parent, title, filename, encoding=None, modal=True, _utest=False):
76-
"Display file in a TextViever or show error message."
91+
"""Create TextViewer for text in filename.
92+
93+
Return error message if file cannot be read. Otherwise calls view_text
94+
with contents of the file.
95+
"""
7796
try:
7897
with open(filename, 'r', encoding=encoding) as file:
7998
contents = file.read()

0 commit comments

Comments
 (0)