Commit 9b84cc87 authored by Serhiy Storchaka's avatar Serhiy Storchaka Committed by GitHub

[2.7] bpo-33974: Fix passing special characters to ttk widgets. (GH-7986) (GH-8021)

Fix passing lists and tuples of strings containing special characters
'"', '\\', '{', '}' and '\n' as options to tkinter.ttk widgets.
(cherry picked from commit 5bb5bbfc)
parent 0464de0f
...@@ -71,7 +71,7 @@ def _stringify(value): ...@@ -71,7 +71,7 @@ def _stringify(value):
if isinstance(value, (list, tuple)): if isinstance(value, (list, tuple)):
if len(value) == 1: if len(value) == 1:
value = _stringify(value[0]) value = _stringify(value[0])
if value[0] == '{': if _magic_re.search(value):
value = '{%s}' % value value = '{%s}' % value
else: else:
value = '{%s}' % _join(value) value = '{%s}' % _join(value)
...@@ -85,7 +85,10 @@ def _stringify(value): ...@@ -85,7 +85,10 @@ def _stringify(value):
elif _magic_re.search(value): elif _magic_re.search(value):
# add '\' before special characters and spaces # add '\' before special characters and spaces
value = _magic_re.sub(r'\\\1', value) value = _magic_re.sub(r'\\\1', value)
value = value.replace('\n', r'\n')
value = _space_re.sub(r'\\\1', value) value = _space_re.sub(r'\\\1', value)
if value[0] == '"':
value = '\\' + value
elif value[0] == '"' or _space_re.search(value): elif value[0] == '"' or _space_re.search(value):
value = '{%s}' % value value = '{%s}' % value
return value return value
......
...@@ -661,6 +661,43 @@ class TclTest(unittest.TestCase): ...@@ -661,6 +661,43 @@ class TclTest(unittest.TestCase):
expected = {'a': (1, 2, 3), 'something': 'foo', 'status': ''} expected = {'a': (1, 2, 3), 'something': 'foo', 'status': ''}
self.assertEqual(splitdict(tcl, arg), expected) self.assertEqual(splitdict(tcl, arg), expected)
def test_join(self):
join = tkinter._join
tcl = self.interp.tk
def unpack(s):
return tcl.call('lindex', s, 0)
def check(value):
self.assertEqual(unpack(join([value])), value)
self.assertEqual(unpack(join([value, 0])), value)
self.assertEqual(unpack(unpack(join([[value]]))), value)
self.assertEqual(unpack(unpack(join([[value, 0]]))), value)
self.assertEqual(unpack(unpack(join([[value], 0]))), value)
self.assertEqual(unpack(unpack(join([[value, 0], 0]))), value)
check('')
check('spam')
check('sp am')
check('sp\tam')
check('sp\nam')
check(' \t\n')
check('{spam}')
check('{sp am}')
check('"spam"')
check('"sp am"')
check('{"spam"}')
check('"{spam}"')
check('sp\\am')
check('"sp\\am"')
check('"{}" "{}"')
check('"\\')
check('"{')
check('"}')
check('\n\\')
check('\n{')
check('\n}')
check('\\\n')
check('{\n')
check('}\n')
character_size = 4 if sys.maxunicode > 0xFFFF else 2 character_size = 4 if sys.maxunicode > 0xFFFF else 2
......
Fixed passing lists and tuples of strings containing special characters
``"``, ``\``, ``{``, ``}`` and ``\n`` as options to :mod:`~tkinter.ttk`
widgets.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment