#!/usr/bin/python # -*- coding: utf-8 -*- # #Copyright (C) 2009 sp00b, sebnapi # #This program is free software; you can redistribute it and/or modify #it under the terms of the GNU General Public License as published by #the Free Software Foundation; either version 3 of the License, #or (at your option) any later version. # #This program is distributed in the hope that it will be useful, #but WITHOUT ANY WARRANTY; without even the implied warranty of #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. #See the GNU General Public License for more details. # #You should have received a copy of the GNU General Public License # along with this program; if not, see . # ### import threading from time import time, sleep from copy import copy import urllib class Status(object): """ Saves all status information """ def __init__(self, pyfile): self.pyfile = pyfile self.type = None self.status_queue = None self.total_kb = 0 self.downloaded_kb = 0 self.rate = 0 self.expected_time = 0 self.filename = None self.url = None self.exists = None self.waituntil = None self.want_reconnect = None def __call__(self, blocks_read, block_size, total_size): if self.status_queue == None: return False self.start = time() self.last_status = time() self.total_kb = total_size / 1024 self.downloaded_kb = (blocks_read * block_size) / 1024 elapsed_time = time() - self.start if elapsed_time != 0: self.rate = self.downloaded_kb / elapsed_time if self.rate != 0: self.expected_time = self.downloaded_kb / self.rate if self.last_status+0.2 < time(): self.status_queue.put(copy(self)) self.last_status = time() def set_status_queue(self, queue): self.status_queue = queue def get_ETA(self): return self.pyfile.plugin.req.get_ETA() def get_speed(self): return self.pyfile.plugin.req.get_speed() def kB_left(self): return self.pyfile.plugins.req.kB_left() class Download_Thread(threading.Thread): def __init__(self, parent): threading.Thread.__init__(self) self.shutdown = False self.parent = parent self.setDaemon(True) self.loadedPyFile = None self.start() def run(self): while (not self.shutdown): if self.parent.py_load_files: self.loadedPyFile = self.parent.get_job() if self.loadedPyFile: self.download(self.loadedPyFile) sleep(0.5) if self.shutdown: sleep(1) self.parent.remove_thread(self) def download(self, py_load_file): pyfile = py_load_file status = pyfile.status pyfile.prepareDownload() if not status.exists: return False if status.want_reconnect: print "handle reconnect" return False while (time() < status.waituntil): status.type = "waiting" sleep(1) #eventuell auf genaue zeit warten status.type = "downloading" print status.url , status.filename try: pyfile.plugin.req.download(status.url, pyfile.download_folder + "/" + status.filename) status.type = "finished" except: status.type = "failed" self.parent.job_finished(pyfile) #startet downloader #urllib.urlretrieve(status.url, pyfile.download_folder + "/" + status.filename, status) #self.shutdown = True