Commit 724a55c5 authored by Ned Deily's avatar Ned Deily

Issue #14777: In an X11 windowing environment, tkinter may return

undecoded UTF-8 bytes as a string when accessing the Tk clipboard.
Modify clipboad_get() to first request type UTF8_STRING when no
specific type is requested in an X11 windowing environment, falling
back to the current default type STRING if that fails.
Original patch by Thomas Kluyver.
parent 580227a8
...@@ -534,12 +534,19 @@ class Misc: ...@@ -534,12 +534,19 @@ class Misc:
The type keyword specifies the form in which the data is The type keyword specifies the form in which the data is
to be returned and should be an atom name such as STRING to be returned and should be an atom name such as STRING
or FILE_NAME. Type defaults to STRING. or FILE_NAME. Type defaults to STRING, except on X11, where the default
is to try UTF8_STRING and fall back to STRING.
This command is equivalent to: This command is equivalent to:
selection_get(CLIPBOARD) selection_get(CLIPBOARD)
""" """
if 'type' not in kw and self._windowingsystem == 'x11':
try:
kw['type'] = 'UTF8_STRING'
return self.tk.call(('clipboard', 'get') + self._options(kw))
except TclError:
del kw['type']
return self.tk.call(('clipboard', 'get') + self._options(kw)) return self.tk.call(('clipboard', 'get') + self._options(kw))
def clipboard_clear(self, **kw): def clipboard_clear(self, **kw):
...@@ -621,8 +628,16 @@ class Misc: ...@@ -621,8 +628,16 @@ class Misc:
A keyword parameter selection specifies the name of A keyword parameter selection specifies the name of
the selection and defaults to PRIMARY. A keyword the selection and defaults to PRIMARY. A keyword
parameter displayof specifies a widget on the display parameter displayof specifies a widget on the display
to use.""" to use. A keyword parameter type specifies the form of data to be
fetched, defaulting to STRING except on X11, where UTF8_STRING is tried
before STRING."""
if 'displayof' not in kw: kw['displayof'] = self._w if 'displayof' not in kw: kw['displayof'] = self._w
if 'type' not in kw and self._windowingsystem == 'x11':
try:
kw['type'] = 'UTF8_STRING'
return self.tk.call(('selection', 'get') + self._options(kw))
except TclError:
del kw['type']
return self.tk.call(('selection', 'get') + self._options(kw)) return self.tk.call(('selection', 'get') + self._options(kw))
def selection_handle(self, command, **kw): def selection_handle(self, command, **kw):
"""Specify a function COMMAND to call if the X """Specify a function COMMAND to call if the X
...@@ -1037,6 +1052,15 @@ class Misc: ...@@ -1037,6 +1052,15 @@ class Misc:
if displayof is None: if displayof is None:
return ('-displayof', self._w) return ('-displayof', self._w)
return () return ()
@property
def _windowingsystem(self):
"""Internal function."""
try:
return self._root()._windowingsystem_cached
except AttributeError:
ws = self._root()._windowingsystem_cached = \
self.tk.call('tk', 'windowingsystem')
return ws
def _options(self, cnf, kw = None): def _options(self, cnf, kw = None):
"""Internal function.""" """Internal function."""
if kw: if kw:
......
...@@ -60,6 +60,12 @@ Core and Builtins ...@@ -60,6 +60,12 @@ Core and Builtins
Library Library
------- -------
- Issue #14777: tkinter may return undecoded UTF-8 bytes as a string when
accessing the Tk clipboard. Modify clipboad_get() to first request type
UTF8_STRING when no specific type is requested in an X11 windowing
environment, falling back to the current default type STRING if that fails.
Original patch by Thomas Kluyver.
- Issue #12541: Be lenient with quotes around Realm field with HTTP Basic - Issue #12541: Be lenient with quotes around Realm field with HTTP Basic
Authentation in urllib2. Authentation in urllib2.
......
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