summaryrefslogtreecommitdiffstats
path: root/module/network
diff options
context:
space:
mode:
Diffstat (limited to 'module/network')
-rw-r--r--module/network/HTTPChunk.py4
-rw-r--r--module/network/HTTPDownload.py24
2 files changed, 16 insertions, 12 deletions
diff --git a/module/network/HTTPChunk.py b/module/network/HTTPChunk.py
index ee143330e..fc2310715 100644
--- a/module/network/HTTPChunk.py
+++ b/module/network/HTTPChunk.py
@@ -232,8 +232,8 @@ class HTTPChunk(HTTPRequest):
"""parse data from recieved header"""
for orgline in self.decodeResponse(self.header).splitlines():
line = orgline.strip().lower()
- if line.startswith("accept-ranges") and "bytes" in line:
- self.p.chunkSupport = True
+# if line.startswith("accept-ranges") and "bytes" in line:
+# self.p.chunkSupport = True
if line.startswith("content-disposition") and "filename=" in line:
name = orgline.partition("filename=")[2]
diff --git a/module/network/HTTPDownload.py b/module/network/HTTPDownload.py
index 781929b9d..b5f6313d5 100644
--- a/module/network/HTTPDownload.py
+++ b/module/network/HTTPDownload.py
@@ -63,7 +63,6 @@ class HTTPDownload():
self.m = pycurl.CurlMulti()
#needed for speed calculation
- self.lastChecked = 0
self.lastArrived = []
self.speeds = []
self.lastSpeeds = [0, 0]
@@ -148,7 +147,9 @@ class HTTPDownload():
self.chunks.append(init)
self.m.add_handle(init.getHandle())
- chunksDone = 0
+ lastFinishCheck = 0
+ lastTimeCheck = 0
+ chunksDone = set()
chunksCreated = False
if self.info.getCount() > 1: # This is a resume, if we were chunked originally assume still can
self.chunkSupport=True
@@ -186,10 +187,13 @@ class HTTPDownload():
if ret != pycurl.E_CALL_MULTI_PERFORM:
break
- while 1:
+ t = time()
+
+ # reduce these calls
+ while lastFinishCheck + 1 < t:
num_q, ok_list, err_list = self.m.info_read()
for c in ok_list:
- chunksDone += 1
+ chunksDone.add(c)
for c in err_list:
curl, errno, msg = c
#test if chunk was finished, otherwise raise the exception
@@ -199,24 +203,24 @@ class HTTPDownload():
#@TODO KeyBoardInterrupts are seen as finished chunks,
#but normally not handled to this process, only in the testcase
- chunksDone += 1
+ chunksDone.add(c[0])
if not num_q:
+ lastFinishCheck = t
break
- if chunksDone == len(self.chunks):
+ if len(chunksDone) == len(self.chunks):
break #all chunks loaded
# calc speed once per second
- t = time()
- if self.lastChecked + 1 < t:
+ if lastTimeCheck + 1 < t:
diff = [c.arrived - (self.lastArrived[i] if len(self.lastArrived) > i else 0) for i, c in
enumerate(self.chunks)]
self.lastSpeeds[1] = self.lastSpeeds[0]
self.lastSpeeds[0] = self.speeds
- self.speeds = [float(a) / (t - self.lastChecked) for a in diff]
+ self.speeds = [float(a) / (t - lastTimeCheck) for a in diff]
self.lastArrived = [c.arrived for c in self.chunks]
- self.lastChecked = t
+ lastTimeCheck = t
self.updateProgress()
if self.abort: