summaryrefslogtreecommitdiffstats
path: root/pym/_emerge
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2009-10-26 22:26:31 +0000
committerZac Medico <zmedico@gentoo.org>2009-10-26 22:26:31 +0000
commitad9e5fe8a557b1cb0b54aeb5268eb209abfaf0c8 (patch)
tree65d16296bca818bddadb9583d709059449ce0beb /pym/_emerge
parent403624a789efd1476a1a00a5c9808a5c1e8fe830 (diff)
downloadportage-ad9e5fe8a557b1cb0b54aeb5268eb209abfaf0c8.tar.gz
portage-ad9e5fe8a557b1cb0b54aeb5268eb209abfaf0c8.tar.bz2
portage-ad9e5fe8a557b1cb0b54aeb5268eb209abfaf0c8.zip
Bug #290625 - Manually encode output to stdout in python3, in order to avoid
potential UnicodeEncodeError exceptions. svn path=/main/trunk/; revision=14734
Diffstat (limited to 'pym/_emerge')
-rw-r--r--pym/_emerge/JobStatusDisplay.py14
1 files changed, 9 insertions, 5 deletions
diff --git a/pym/_emerge/JobStatusDisplay.py b/pym/_emerge/JobStatusDisplay.py
index 1c80c5ffa..bcc682b23 100644
--- a/pym/_emerge/JobStatusDisplay.py
+++ b/pym/_emerge/JobStatusDisplay.py
@@ -17,6 +17,7 @@ import portage
from portage import os
from portage import _encodings
from portage import _unicode_decode
+from portage import _unicode_encode
from portage.output import xtermTitle
from _emerge.getloadavg import getloadavg
@@ -75,11 +76,14 @@ class JobStatusDisplay(object):
return sys.stdout
def _write(self, s):
- if sys.hexversion < 0x3000000 and isinstance(s, unicode):
- # avoid potential UnicodeEncodeError
- s = s.encode(_encodings['stdio'], 'backslashreplace')
- self.out.write(s)
- self.out.flush()
+ # avoid potential UnicodeEncodeError
+ s = _unicode_encode(s,
+ encoding=_encodings['stdio'], errors='backslashreplace')
+ out = self.out
+ if sys.hexversion >= 0x3000000:
+ out = out.buffer
+ out.write(s)
+ out.flush()
def _init_term(self):
"""