summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/network/HTTPChunk.py14
-rw-r--r--module/plugins/hoster/FilesMailRu.py2
2 files changed, 13 insertions, 3 deletions
diff --git a/module/network/HTTPChunk.py b/module/network/HTTPChunk.py
index 573ed1766..89770769f 100644
--- a/module/network/HTTPChunk.py
+++ b/module/network/HTTPChunk.py
@@ -142,6 +142,8 @@ class HTTPChunk(HTTPRequest):
self.c.setopt(pycurl.WRITEFUNCTION, self.writeBody)
self.c.setopt(pycurl.HEADERFUNCTION, self.writeHeader)
+ # request one byte more, since some servers in russia seems to have a defect arihmetic unit
+
if self.resume:
self.fp = open(self.p.info.getChunkName(self.id), "ab")
self.arrived = self.fp.tell()
@@ -150,7 +152,11 @@ class HTTPChunk(HTTPRequest):
#do nothing if chunk already finished
if not self.arrived + self.range[0] - self.range[1]: return None
- range = "%i-%i" % (self.arrived + self.range[0], self.range[1])
+ if self.id == len(self.p.info.chunks) - 1: #as last chunk dont set end range, so we get everything
+ range = "%i-" % self.range[0]
+ else:
+ range = "%i-%i" % (self.arrived + self.range[0], min(self.range[1] + 1, self.p.size - 1))
+
print "Chunked resume with range %s" % range
self.c.setopt(pycurl.RANGE, range)
else:
@@ -159,7 +165,11 @@ class HTTPChunk(HTTPRequest):
else:
if self.range:
- range = "%i-%i" % self.range
+ if self.id == len(self.p.info.chunks) - 1: # see above
+ range = "%i-" % self.range[0]
+ else:
+ range = "%i-%i" % (self.range[0], min(self.range[1] + 1, self.p.size - 1))
+
print "Chunked with range %s" % range
self.c.setopt(pycurl.RANGE, range)
diff --git a/module/plugins/hoster/FilesMailRu.py b/module/plugins/hoster/FilesMailRu.py
index ff6cb76a9..3fa40cbd0 100644
--- a/module/plugins/hoster/FilesMailRu.py
+++ b/module/plugins/hoster/FilesMailRu.py
@@ -41,7 +41,7 @@ class FilesMailRu(Hoster):
def setup(self):
self.multiDL = True
self.resumeDownload = True
- self.chunkLimit = 1
+ self.chunkLimit = -1
def process(self, pyfile):
self.html = self.load(pyfile.url)