From 0c71f83404d17e27b1fc319ad6979969c6205062 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Mon, 12 Jul 2010 04:49:55 -0700 Subject: Fix output handling for FEATURES="lafilefixing". --- pym/_emerge/EbuildPhase.py | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) (limited to 'pym/_emerge') diff --git a/pym/_emerge/EbuildPhase.py b/pym/_emerge/EbuildPhase.py index 51ee93da6..8d20fd878 100644 --- a/pym/_emerge/EbuildPhase.py +++ b/pym/_emerge/EbuildPhase.py @@ -58,18 +58,21 @@ class EbuildPhase(CompositeTask): settings = self.settings if self.phase == "install": - out = None - log_path = self.settings.get("PORTAGE_LOG_FILE") - log_file = None - if self.background and log_path is not None: - log_file = codecs.open(_unicode_encode(log_path, - encoding=_encodings['fs'], errors='strict'), - mode='a', encoding=_encodings['content'], errors='replace') - out = log_file + out = portage.StringIO() _post_src_install_chost_fix(settings) - _post_src_install_uid_fix(settings, out=out) - if log_file is not None: - log_file.close() + _post_src_install_uid_fix(settings, out) + msg = _unicode_decode(out.getvalue(), + encoding=_encodings['content'], errors='replace') + if msg: + if not self.background: + writemsg_stdout(msg, noiselevel=-1) + log_path = self.settings.get("PORTAGE_LOG_FILE") + if log_path is not None: + log_file = codecs.open(_unicode_encode(log_path, + encoding=_encodings['fs'], errors='strict'), + mode='a', encoding=_encodings['content'], errors='replace') + log_file.write(msg) + log_file.close() post_phase_cmds = _post_phase_cmds.get(self.phase) if post_phase_cmds is not None: -- cgit v1.2.3-1-g7c22