From: Zac Medico Date: Fri, 16 Dec 2011 19:56:01 +0000 (-0800) Subject: PipeReader: use AbstractPollTask._read_buf() X-Git-Tag: v2.2.0_alpha82~56 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=2eea0db1855009c3407ba6eae1dc095297769989;p=portage.git PipeReader: use AbstractPollTask._read_buf() --- diff --git a/pym/_emerge/PipeReader.py b/pym/_emerge/PipeReader.py index a465c2a28..9fedbff6f 100644 --- a/pym/_emerge/PipeReader.py +++ b/pym/_emerge/PipeReader.py @@ -3,8 +3,6 @@ from portage import os from _emerge.AbstractPollTask import AbstractPollTask -from _emerge.PollConstants import PollConstants -import errno import fcntl class PipeReader(AbstractPollTask): @@ -57,30 +55,16 @@ class PipeReader(AbstractPollTask): def _output_handler(self, fd, event): - if event & PollConstants.POLLIN: - - while True: - data = None - try: - data = os.read(fd, self._bufsize) - except OSError as e: - # EIO happens with pty on Linux after the - # slave end of the pty has been closed. - if e.errno == errno.EIO: - self._unregister() - self.wait() - break - elif e.errno == errno.EAGAIN: - break - else: - raise - else: - if data: - self._read_data.append(data) - else: - self._unregister() - self.wait() - break + while True: + data = self._read_buf(fd, event) + if data is None: + break + if data: + self._read_data.append(data) + else: + self._unregister() + self.wait() + break self._unregister_if_appropriate(event)