summaryrefslogtreecommitdiffstats
path: root/module/network/HTTPChunk.py
diff options
context:
space:
mode:
Diffstat (limited to 'module/network/HTTPChunk.py')
-rw-r--r--module/network/HTTPChunk.py26
1 files changed, 11 insertions, 15 deletions
diff --git a/module/network/HTTPChunk.py b/module/network/HTTPChunk.py
index f9ad3def7..c7d981880 100644
--- a/module/network/HTTPChunk.py
+++ b/module/network/HTTPChunk.py
@@ -42,7 +42,6 @@ class HTTPChunk(HTTPBase):
self.deferred = Deferred()
- self.lock = Lock()
self.abort = False
self.finished = False
@@ -59,10 +58,7 @@ class HTTPChunk(HTTPBase):
self.resp = None
def getSpeed(self):
- self.lock.acquire()
- speed = self.speed
- self.lock.release()
- return speed
+ return self.speed
@threaded
def _download(self, resp):
@@ -80,8 +76,8 @@ class HTTPChunk(HTTPBase):
if self.noRangeHeader:
count = min(count, self.range[1] - self.arrived)
if self.bucket:
- count = self.bucket.add(count)
- if count == 0:
+ allow = self.bucket.consume(count)
+ if not allow:
sleep(0.01)
continue
@@ -92,17 +88,17 @@ class HTTPChunk(HTTPBase):
break
if self.speedCalcTime < inttime():
- self.lock.acquire()
self.speed = self.speedCalcLen
- self.lock.release()
self.speedCalcTime = inttime()
self.speedCalcLen = 0
size = len(data)
- if self.noRangeHeader and self.arrived+size == self.range[1]:
- running = False
- self.speedCalcLen += size
- self.arrived += size
+ self.arrived += size
+ self.speedCalcLen += size
+
+ if self.noRangeHeader and self.arrived == self.range[1]:
+ running = False
+
if data:
self.fh.write(data)
else:
@@ -150,8 +146,8 @@ if __name__ == "__main__":
import sys
from Bucket import Bucket
bucket = Bucket()
- #bucket.setRate(200*1000)
- bucket = None
+ bucket.setRate(200*1000)
+ #bucket = None
url = "http://speedtest.netcologne.de/test_100mb.bin"