diff options
| author | 2009-12-04 20:01:17 +0100 | |
|---|---|---|
| committer | 2009-12-04 20:01:17 +0100 | |
| commit | 78f061eed59e084f001f8a0cd9c5b585f6fc0ce0 (patch) | |
| tree | 1c5cc3cbfa4eb993a5af0f2b6556e1ff5f0021c7 | |
| parent | Convert read_url_list to new Plugin (diff) | |
| download | pyload-78f061eed59e084f001f8a0cd9c5b585f6fc0ce0.tar.xz | |
fixes, minimal gui changes
| -rw-r--r-- | module/Plugin.py | 5 | ||||
| -rw-r--r-- | module/file_list.py | 16 | ||||
| -rw-r--r-- | module/plugins/RapidshareCom.py | 7 | ||||
| -rw-r--r-- | module/thread_list.py | 16 | ||||
| -rw-r--r-- | pyLoadQtGui.py | 23 | 
5 files changed, 53 insertions, 14 deletions
| diff --git a/module/Plugin.py b/module/Plugin.py index 7b726c3ac..f343dc62f 100644 --- a/module/Plugin.py +++ b/module/Plugin.py @@ -89,7 +89,10 @@ class Plugin():          return self.parent.url      def get_file_name(self): -        return re.findall("([^\/=]+)", self.parent.url)[-1] +        try: +            return re.findall("([^\/=]+)", self.parent.url)[-1] +        except: +            return "no_name"      def wait_until(self):          if self.html != None: diff --git a/module/file_list.py b/module/file_list.py index f66567e0f..2bfe37298 100644 --- a/module/file_list.py +++ b/module/file_list.py @@ -136,7 +136,7 @@ class File_List(object):          try:              n, pyfile = self.collector._getFileFromID(id)          except NoSuchElementException: -            key, n, pyfile, pypack, pid = self.packager._getFileFromID() +            key, n, pyfile, pypack, pid = self.packager._getFileFromID(id)          info = {}          info["id"] = pyfile.id          info["url"] = pyfile.url @@ -146,6 +146,7 @@ class File_List(object):          info["status_url"] = pyfile.status.url          info["status_filename"] = pyfile.status.filename          info["status_error"] = pyfile.status.error +        info["active"] = pyfile.active          return info      class pyLoadCollector(): @@ -260,11 +261,11 @@ class File_List(object):              for n, pypack in enumerate(packager.file_list.data["packages"]):                  for pyfile in pypack.files:                      if pyfile.id == id: -                        return ("packages", n, pyfile, pypack, pid) +                        return ("packages", n, pyfile, pypack, pypack.data["id"])              for n, pypack in enumerate(packager.file_list.data["queue"]):                  for pyfile in pypack.files:                      if pyfile.id == id: -                        return ("queue", n, pyfile, pypack, pid) +                        return ("queue", n, pyfile, pypack, pypack.data["id"])              raise NoSuchElementException()          def addNewPackage(packager, package_name=None): @@ -291,6 +292,8 @@ class File_List(object):              try:                  key, n, pyfile, pypack, pid = self._getFileFromID()                  del pypack.files[n] +                if not pypack.files: +                    packager.removePackage(pid)              finally:                  packager.file_list.lock.release() @@ -343,11 +346,14 @@ class File_List(object):              pypack.files.append(pyfile)              packager.file_list.data[key][n] = pypack +       #oooops, duplicate?          def removeFileFromPackage(packager, id, pid):              key, n, pypack = packager._getPackageFromID(pid)              for k, pyfile in enumerate(pypack.files):                  if id == pyfile.id:                      del pypack.files[k] +                    if not pypack.files: +                        packager.removePackage(pid)                      return True              raise NoSuchElementException() @@ -368,7 +374,7 @@ class PyLoadFile():          self.file_list = file_list          self.core = file_list.core          self.package = None -        self.filename = "filename" +        self.filename = "n/a"          self.download_folder = ""          self.active = False          pluginName = self._get_my_plugin() @@ -380,6 +386,8 @@ class PyLoadFile():              pluginClass = module.Plugin.Plugin          self.plugin = pluginClass(self)          self.status = Status(self) +        if self.plugin.file_exists(): +            self.filename = self.plugin.get_file_name()      def _get_my_plugin(self):          for plugin, plugin_pattern in self.core.plugins_avaible.items(): diff --git a/module/plugins/RapidshareCom.py b/module/plugins/RapidshareCom.py index 7daff3f8f..f7bcb5de8 100644 --- a/module/plugins/RapidshareCom.py +++ b/module/plugins/RapidshareCom.py @@ -27,6 +27,7 @@ class RapidshareCom(Plugin):          self.time_plus_wait = None   #time() + wait in seconds          self.want_reconnect = False          self.no_slots = True +        self.api_data = None          #~ self.logger = logging.getLogger("log")          self.read_config()          if self.config['premium']: @@ -153,6 +154,8 @@ class RapidshareCom(Plugin):      def file_exists(self):          """ returns True or False          """ +        if self.html[0] == None: +            self.download_html()          if re.search("The file could not be found|This limit is reached| \              is momentarily not available|removed this file| \              contain illegal content", self.html[0], re.I) != None: @@ -190,6 +193,10 @@ class RapidshareCom(Plugin):              #raise Exception, "Error when retrieving download url"      def get_file_name(self): +        if self.html[0] == None: +            self.download_html() +        if self.api_data == None: +            self.download_api_data()          if self.api_data and self.api_data["filename"]:              return self.api_data["filename"]          file_name_pattern = r"<p class=\"downloadlink\">.+/(.+) <font" diff --git a/module/thread_list.py b/module/thread_list.py index 55f237544..3c69121c2 100644 --- a/module/thread_list.py +++ b/module/thread_list.py @@ -107,14 +107,16 @@ class Thread_List(object):          if pyfile.status.type == "finished":              if pyfile.plugin.props['type'] == "container":                  #works(!) but adds many packs to queue +                self.list.packager.removeFileFromPackage(pyfile.id, pyfile.package.data["id"])                  newLinks = 0 -                newPackager = self.list.packager.addNewPackage(pyfile.status.filename) -                for link in pyfile.plugin.links: -                    newFile =  self.list.collector.addLink(link) -                    self.list.packager.addFileToPackage(newPackager, self.list.collector.popFile(newFile)) -                    newLinks += 1 -                self.list.packager.pushPackage2Queue(newPackager) - +                if pyfile.plugin.links: +                    newPackager = self.list.packager.addNewPackage(pyfile.status.filename) +                    for link in pyfile.plugin.links: +                        newFile = self.list.collector.addLink(link) +                        self.list.packager.addFileToPackage(newPackager, self.list.collector.popFile(newFile)) +                        newLinks += 1 +                    self.list.packager.pushPackage2Queue(newPackager) +                      if newLinks:                      self.parent.logger.info("Parsed link from %s: %i" % (pyfile.status.filename, newLinks))                  else: diff --git a/pyLoadQtGui.py b/pyLoadQtGui.py index 88882a159..a67e80d66 100644 --- a/pyLoadQtGui.py +++ b/pyLoadQtGui.py @@ -81,6 +81,11 @@ class main(QObject):              item = QTreeWidgetItem()              item.setData(0, Qt.UserRole, QVariant(data))              item.setData(0, Qt.DisplayRole, QVariant(data["package_name"])) +            files = self.connector.getPackageFiles(data["id"]) +            for id in files: +                info = self.connector.getLinkInfo(id) +                sub = QTreeWidgetItem(item) +                sub.setData(0, Qt.DisplayRole, QVariant(info["filename"]))              self.mainWindow.tabs["collector_packages"]["treewidget"].addTopLevelItem(item)          #test for queue @@ -89,6 +94,12 @@ class main(QObject):              item = QTreeWidgetItem()              item.setData(0, Qt.UserRole, QVariant(data))              item.setData(0, Qt.DisplayRole, QVariant(data["package_name"])) +            files = self.connector.getPackageFiles(data["id"]) +            for id in files: +                info = self.connector.getLinkInfo(id) +                sub = QTreeWidgetItem(item) +                sub.setData(0, Qt.DisplayRole, QVariant(info["filename"])) +                sub.setData(1, Qt.DisplayRole, QVariant(info["status_type"]))              self.mainWindow.tabs["queue"]["treewidget"].addTopLevelItem(item)  class connector(QThread): @@ -154,6 +165,12 @@ class connector(QThread):              grab queue return the data          """          return self.proxy.get_queue() +     +    def getPackageFiles(self, id): +        """ +            grab package files and return ids +        """ +        return self.proxy.get_package_files(id)  class mainWindow(QMainWindow):      def __init__(self): @@ -197,8 +214,8 @@ class mainWindow(QMainWindow):          self.tabs["collector_packages"] = {"w":QWidget()}          self.tabs["collector_links"] = {"w":QWidget()}          self.tabw.addTab(self.tabs["queue"]["w"], "Queue") -        self.tabw.addTab(self.tabs["collector_packages"]["w"], "Link collector") -        self.tabw.addTab(self.tabs["collector_links"]["w"], "Package collector") +        self.tabw.addTab(self.tabs["collector_packages"]["w"], "Package collector") +        self.tabw.addTab(self.tabs["collector_links"]["w"], "Link collector")          #init tabs          self.init_tabs() @@ -215,6 +232,8 @@ class mainWindow(QMainWindow):          self.tabs["queue"]["w"].setLayout(self.tabs["queue"]["l"])          self.tabs["queue"]["treewidget"] = QTreeWidget()          self.tabs["queue"]["l"].addWidget(self.tabs["queue"]["treewidget"]) +        self.tabs["queue"]["treewidget"].setColumnCount(2) +        self.tabs["queue"]["treewidget"].setHeaderLabels(["Name", "Status"])          #collector_packages          self.tabs["collector_packages"]["l"] = QGridLayout() | 
