summaryrefslogtreecommitdiffstats
path: root/pym/_emerge/AbstractEbuildProcess.py
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2011-03-09 21:46:17 -0800
committerZac Medico <zmedico@gentoo.org>2011-03-14 09:23:10 -0700
commit157382fae7b4b4c74a6f7ce319c602c269cc7e96 (patch)
treecceb7c5dc066497f37ce1d241d8773a7f55dcba6 /pym/_emerge/AbstractEbuildProcess.py
parentc1fba51ccab868d05f48fcc40bc2c959c9385e76 (diff)
downloadportage-157382fae7b4b4c74a6f7ce319c602c269cc7e96.tar.gz
portage-157382fae7b4b4c74a6f7ce319c602c269cc7e96.tar.bz2
portage-157382fae7b4b4c74a6f7ce319c602c269cc7e96.zip
AbstractPollTask: log exceptional events
Previously, when AbstractPollTask receives a POLLERR or POLLNVAL event, it would silently cancel the task. Now it will generate a message like this: !!! SpawnProcess received strange poll event: 8 The message is displayed via a new _log_poll_exception method, which is overridden by AbstractEbuildProcess to log the message via elog. This might help diagnose reported cases of SIGTERM signals killing ebuild processes for no apparent reason: http://code.google.com/p/chromium-os/issues/detail?id=12968
Diffstat (limited to 'pym/_emerge/AbstractEbuildProcess.py')
-rw-r--r--pym/_emerge/AbstractEbuildProcess.py5
1 files changed, 5 insertions, 0 deletions
diff --git a/pym/_emerge/AbstractEbuildProcess.py b/pym/_emerge/AbstractEbuildProcess.py
index 601aafe0e..d7f31be28 100644
--- a/pym/_emerge/AbstractEbuildProcess.py
+++ b/pym/_emerge/AbstractEbuildProcess.py
@@ -228,6 +228,11 @@ class AbstractEbuildProcess(SpawnProcess):
self.scheduler.output(msg,
log_path=self.settings.get("PORTAGE_LOG_FILE"))
+ def _log_poll_exception(self, event):
+ self._elog("eerror",
+ ["%s received strange poll event: %s\n" % \
+ (self.__class__.__name__, event,)])
+
def _set_returncode(self, wait_retval):
SpawnProcess._set_returncode(self, wait_retval)