summaryrefslogtreecommitdiffstats
path: root/pym/_emerge/SpawnProcess.py
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2010-09-09 20:05:19 -0700
committerZac Medico <zmedico@gentoo.org>2010-09-09 20:05:19 -0700
commitc299f8d465efad80b17074e1791c20024760648c (patch)
tree5be85e7b02793d898d6e59af161a76bb622c65c8 /pym/_emerge/SpawnProcess.py
parente23e4a36210056ff2d46831f79fa5aa410e0b377 (diff)
downloadportage-c299f8d465efad80b17074e1791c20024760648c.tar.gz
portage-c299f8d465efad80b17074e1791c20024760648c.tar.bz2
portage-c299f8d465efad80b17074e1791c20024760648c.zip
Split out a AbstractPollTask._read_buf() helper method.
Diffstat (limited to 'pym/_emerge/SpawnProcess.py')
-rw-r--r--pym/_emerge/SpawnProcess.py22
1 files changed, 6 insertions, 16 deletions
diff --git a/pym/_emerge/SpawnProcess.py b/pym/_emerge/SpawnProcess.py
index aeb206a06..0cddbe801 100644
--- a/pym/_emerge/SpawnProcess.py
+++ b/pym/_emerge/SpawnProcess.py
@@ -1,8 +1,7 @@
-# Copyright 1999-2009 Gentoo Foundation
+# Copyright 1999-2010 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
from _emerge.SubProcess import SubProcess
-from _emerge.PollConstants import PollConstants
import sys
from portage.cache.mappings import slot_dict_class
import portage
@@ -11,7 +10,6 @@ from portage import _unicode_encode
from portage import os
import fcntl
import errno
-import array
import gzip
class SpawnProcess(SubProcess):
@@ -150,14 +148,10 @@ class SpawnProcess(SubProcess):
def _output_handler(self, fd, event):
- if event & PollConstants.POLLIN:
+ files = self._files
+ buf = self._read_buf(files.process, event)
- files = self._files
- buf = array.array('B')
- try:
- buf.fromfile(files.process, self._bufsize)
- except (EOFError, IOError):
- pass
+ if buf is not None:
if buf:
if not self.background:
@@ -215,13 +209,9 @@ class SpawnProcess(SubProcess):
monitor the process from inside a poll() loop.
"""
- if event & PollConstants.POLLIN:
+ buf = self._read_buf(self._files.process, event)
- buf = array.array('B')
- try:
- buf.fromfile(self._files.process, self._bufsize)
- except (EOFError, IOError):
- pass
+ if buf is not None:
if buf:
pass