mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
gh-97928: Partially restore the behavior of tkinter.Text.count() by default (GH-115031)
By default, it preserves an inconsistent behavior of older Python versions: packs the count into a 1-tuple if only one or none options are specified (including 'update'), returns None instead of 0. Except that setting wantobjects to 0 no longer affects the result. Add a new parameter return_ints: specifying return_ints=True makes Text.count() always returning the single count as an integer instead of a 1-tuple or None.
This commit is contained in:
parent
5d2794a16b
commit
d2c4baa41f
5 changed files with 59 additions and 28 deletions
|
@ -52,27 +52,47 @@ class TextTest(AbstractTkTest, unittest.TestCase):
|
|||
options = ('chars', 'indices', 'lines',
|
||||
'displaychars', 'displayindices', 'displaylines',
|
||||
'xpixels', 'ypixels')
|
||||
self.assertEqual(len(text.count('1.0', 'end', *options, return_ints=True)), 8)
|
||||
self.assertEqual(len(text.count('1.0', 'end', *options)), 8)
|
||||
self.assertEqual(text.count('1.0', 'end', 'chars', 'lines'), (124, 4))
|
||||
self.assertEqual(text.count('1.0', 'end', 'chars', 'lines', return_ints=True),
|
||||
(124, 4))
|
||||
self.assertEqual(text.count('1.3', '4.5', 'chars', 'lines'), (92, 3))
|
||||
self.assertEqual(text.count('4.5', '1.3', 'chars', 'lines', return_ints=True),
|
||||
(-92, -3))
|
||||
self.assertEqual(text.count('4.5', '1.3', 'chars', 'lines'), (-92, -3))
|
||||
self.assertEqual(text.count('1.3', '1.3', 'chars', 'lines', return_ints=True),
|
||||
(0, 0))
|
||||
self.assertEqual(text.count('1.3', '1.3', 'chars', 'lines'), (0, 0))
|
||||
self.assertEqual(text.count('1.0', 'end', 'lines'), 4)
|
||||
self.assertEqual(text.count('end', '1.0', 'lines'), -4)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'lines'), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'lines'), 0)
|
||||
self.assertEqual(text.count('1.0', 'end'), 124) # 'indices' by default
|
||||
self.assertEqual(text.count('1.0', 'end', 'indices'), 124)
|
||||
self.assertEqual(text.count('1.0', 'end', 'lines', return_ints=True), 4)
|
||||
self.assertEqual(text.count('1.0', 'end', 'lines'), (4,))
|
||||
self.assertEqual(text.count('end', '1.0', 'lines', return_ints=True), -4)
|
||||
self.assertEqual(text.count('end', '1.0', 'lines'), (-4,))
|
||||
self.assertEqual(text.count('1.3', '1.5', 'lines', return_ints=True), 0)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'lines'), None)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'lines', return_ints=True), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'lines'), None)
|
||||
# Count 'indices' by default.
|
||||
self.assertEqual(text.count('1.0', 'end', return_ints=True), 124)
|
||||
self.assertEqual(text.count('1.0', 'end'), (124,))
|
||||
self.assertEqual(text.count('1.0', 'end', 'indices', return_ints=True), 124)
|
||||
self.assertEqual(text.count('1.0', 'end', 'indices'), (124,))
|
||||
self.assertRaises(tkinter.TclError, text.count, '1.0', 'end', 'spam')
|
||||
self.assertRaises(tkinter.TclError, text.count, '1.0', 'end', '-lines')
|
||||
|
||||
self.assertIsInstance(text.count('1.3', '1.5', 'ypixels'), int)
|
||||
self.assertIsInstance(text.count('1.3', '1.5', 'ypixels', return_ints=True), int)
|
||||
self.assertIsInstance(text.count('1.3', '1.5', 'ypixels'), tuple)
|
||||
self.assertIsInstance(text.count('1.3', '1.5', 'update', 'ypixels', return_ints=True), int)
|
||||
self.assertIsInstance(text.count('1.3', '1.5', 'update', 'ypixels'), int)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'ypixels'), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'ypixels', return_ints=True), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'ypixels'), None)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'update', 'indices', return_ints=True), 2)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'update', 'indices'), 2)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'indices'), 0)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'update'), 2)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update'), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'indices', return_ints=True), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', 'indices'), None)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'update', return_ints=True), 2)
|
||||
self.assertEqual(text.count('1.3', '1.5', 'update'), (2,))
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update', return_ints=True), 0)
|
||||
self.assertEqual(text.count('1.3', '1.3', 'update'), None)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue