diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2002-08-10 12:22:12 +0000 |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2002-08-10 12:22:12 +0000 |
commit | 75ea1e11dcb90c768af6a222ae8e20a4f532617d (patch) | |
tree | fe1c3b7ac1e5e7876b0daa799056bd6032147c52 /Tools/idle/OutputWindow.py | |
parent | 3ddb856ed1fcfbfb750b00a60b9a5df76555751e (diff) | |
download | cpython-git-75ea1e11dcb90c768af6a222ae8e20a4f532617d.tar.gz |
Convert characters from the locale's encoding on output.
Reject characters outside the locale's encoding on input.
Diffstat (limited to 'Tools/idle/OutputWindow.py')
-rw-r--r-- | Tools/idle/OutputWindow.py | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/Tools/idle/OutputWindow.py b/Tools/idle/OutputWindow.py index f429f2e8bf..0e7fba231a 100644 --- a/Tools/idle/OutputWindow.py +++ b/Tools/idle/OutputWindow.py @@ -2,6 +2,7 @@ from Tkinter import * from EditorWindow import EditorWindow import re import tkMessageBox +import IOBinding class OutputWindow(EditorWindow): @@ -34,6 +35,14 @@ class OutputWindow(EditorWindow): # Act as output file def write(self, s, tags=(), mark="insert"): + # Tk assumes that byte strings are Latin-1; + # we assume that they are in the locale's encoding + if isinstance(s, str): + try: + s = unicode(s, IOBinding.encoding) + except UnicodeError: + # some other encoding; let Tcl deal with it + pass self.text.insert(mark, s, tags) self.text.see(mark) self.text.update() |