diff options
author | Victor Stinner <victor.stinner@haypocalc.com> | 2010-08-17 22:49:25 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@haypocalc.com> | 2010-08-17 22:49:25 (GMT) |
commit | 0e5a41b8f5b87bf07ed6368df5a84137d3e4e4da (patch) | |
tree | 0aa8ac3b1b77729645b770c27b205f030a033d91 /Tools | |
parent | 6961bd690e617b963a55ce86a640eedb590bc23b (diff) | |
download | cpython-0e5a41b8f5b87bf07ed6368df5a84137d3e4e4da.zip cpython-0e5a41b8f5b87bf07ed6368df5a84137d3e4e4da.tar.gz cpython-0e5a41b8f5b87bf07ed6368df5a84137d3e4e4da.tar.bz2 |
libpython.py: py-bt commands escape unencodable characters
Encode unicode strings to the terminal encoding with backslashreplace error (as
Python does for sys.stderr) before writing them to sys.stdout. It fixes
UnicodeEncodeError on writing non-ascii characters in an ascii terminal (C
locale: ASCII encoding).
Diffstat (limited to 'Tools')
-rw-r--r-- | Tools/gdb/libpython.py | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/Tools/gdb/libpython.py b/Tools/gdb/libpython.py index ac4aff5..b23a22e 100644 --- a/Tools/gdb/libpython.py +++ b/Tools/gdb/libpython.py @@ -88,6 +88,13 @@ def safe_range(val): # threshold in case the data was corrupted return xrange(safety_limit(val)) +def write_unicode(file, text): + # Write a byte or unicode string to file. Unicode strings are encoded to + # ENCODING encoding with 'backslashreplace' error handler to avoid + # UnicodeEncodeError. + if isinstance(text, unicode): + text = text.encode(ENCODING, 'backslashreplace') + file.write(text) class StringTruncated(RuntimeError): pass @@ -1360,7 +1367,8 @@ class Frame(object): if self.is_evalframeex(): pyop = self.get_pyop() if pyop: - sys.stdout.write('#%i %s\n' % (self.get_index(), pyop.get_truncated_repr(MAX_OUTPUT_LEN))) + line = pyop.get_truncated_repr(MAX_OUTPUT_LEN) + write_unicode(sys.stdout, '#%i %s\n' % (self.get_index(), line)) sys.stdout.write(pyop.current_line()) else: sys.stdout.write('#%i (unable to read python frame information)\n' % self.get_index()) |