diff options
author | Zac Medico <zmedico@gentoo.org> | 2010-10-06 15:19:25 -0700 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2010-10-06 15:19:25 -0700 |
commit | f5e237f6489f232ec5ada8566e4c35618e9e6d13 (patch) | |
tree | 4221cbacf7c6911b49d16dfd7b3ea6ad4d68c159 /pym/_emerge/FifoIpcDaemon.py | |
parent | d08d8da197798a45c423dd0cf54c63a2badcb317 (diff) | |
download | portage-f5e237f6489f232ec5ada8566e4c35618e9e6d13.tar.gz portage-f5e237f6489f232ec5ada8566e4c35618e9e6d13.tar.bz2 portage-f5e237f6489f232ec5ada8566e4c35618e9e6d13.zip |
Add FifoIpcDaemon._reopen_input() method.
Diffstat (limited to 'pym/_emerge/FifoIpcDaemon.py')
-rw-r--r-- | pym/_emerge/FifoIpcDaemon.py | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/pym/_emerge/FifoIpcDaemon.py b/pym/_emerge/FifoIpcDaemon.py index b879fda95..ac83646b9 100644 --- a/pym/_emerge/FifoIpcDaemon.py +++ b/pym/_emerge/FifoIpcDaemon.py @@ -27,6 +27,19 @@ class FifoIpcDaemon(AbstractPollTask): self._registered = True + def _reopen_input(self): + """ + Re-open the input stream, in order to suppress + POLLHUP events (bug #339976). + """ + self._files.pipe_in.close() + input_fd = os.open(self.input_fifo, os.O_RDONLY|os.O_NONBLOCK) + self._files.pipe_in = os.fdopen(input_fd, 'rb', 0) + self.scheduler.unregister(self._reg_id) + self._reg_id = self.scheduler.register( + self._files.pipe_in.fileno(), + self._registered_events, self._input_handler) + def isAlive(self): return self._registered |