summaryrefslogtreecommitdiff
path: root/apt
diff options
context:
space:
mode:
authorMichael Vogt <michael.vogt@ubuntu.com>2006-09-18 18:42:20 +0200
committerMichael Vogt <michael.vogt@ubuntu.com>2006-09-18 18:42:20 +0200
commita9dd5cc00d723bedc06a0d17c7ede97fb66c14fd (patch)
tree6739b10caae2a5fd1bba2d40231cb5dfcb42db53 /apt
parent283dade78ce3cb31d09dcbc3407b83eedb6d59e4 (diff)
parent8df7cb6c729a5451f231f2cd3e82fc495eaea289 (diff)
downloadpython-apt-a9dd5cc00d723bedc06a0d17c7ede97fb66c14fd.tar.gz
* merged from python-apt--main
Diffstat (limited to 'apt')
-rw-r--r--apt/progress.py18
1 files changed, 13 insertions, 5 deletions
diff --git a/apt/progress.py b/apt/progress.py
index 4119067c..8ac0e1dc 100644
--- a/apt/progress.py
+++ b/apt/progress.py
@@ -19,7 +19,14 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
# USA
-import sys, apt_pkg, os, fcntl, string, re
+import sys
+import os
+import re
+import fcntl
+import string
+from errno import *
+import select
+import apt_pkg
class OpProgress(object):
""" Abstract class to implement reporting on cache opening
@@ -139,6 +146,7 @@ class InstallProgress(DumbInstallProgress):
"""
def __init__(self):
DumbInstallProgress.__init__(self)
+ self.selectTimeout = 0.1
(read, write) = os.pipe()
self.writefd=write
self.statusfd = os.fdopen(read, "r")
@@ -162,7 +170,7 @@ class InstallProgress(DumbInstallProgress):
self.read += os.read(self.statusfd.fileno(),1)
except OSError, (errno,errstr):
# resource temporarly unavailable is ignored
- if errno != 11:
+ if errno != EAGAIN and errnor != EWOULDBLOCK:
print errstr
if self.read.endswith("\n"):
s = self.read
@@ -184,22 +192,22 @@ class InstallProgress(DumbInstallProgress):
self.percent = float(percent)
self.status = string.strip(status_str)
self.read = ""
-
def fork(self):
return os.fork()
def waitChild(self):
while True:
+ select.select([self.statusfd],[],[], self.selectTimeout)
+ self.updateInterface()
(pid, res) = os.waitpid(self.child_pid,os.WNOHANG)
if pid == self.child_pid:
break
- self.updateInterface()
return os.WEXITSTATUS(res)
def run(self, pm):
pid = self.fork()
if pid == 0:
# child
res = pm.DoInstall(self.writefd)
- sys.exit(res)
+ os._exit(res)
self.child_pid = pid
res = self.waitChild()
return res