summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
authorGravatar mkaay <mkaay@mkaay.de> 2011-02-13 20:45:33 +0100
committerGravatar mkaay <mkaay@mkaay.de> 2011-02-13 20:45:33 +0100
commit4c39545bbeb661c564b392fe3ff28fab2713a53e (patch)
treeadcfc665f8b1f83b6d608c994bd21b166be24910 /module
parentfixes + improvements (diff)
downloadpyload-4c39545bbeb661c564b392fe3ff28fab2713a53e.tar.xz
collector size
Diffstat (limited to 'module')
-rw-r--r--module/gui/Collector.py46
-rw-r--r--module/gui/Queue.py14
-rw-r--r--module/remote/thriftbackend/Handler.py10
3 files changed, 44 insertions, 26 deletions
diff --git a/module/gui/Collector.py b/module/gui/Collector.py
index 0711a811e..39310a45d 100644
--- a/module/gui/Collector.py
+++ b/module/gui/Collector.py
@@ -41,13 +41,25 @@ statusMapReverse = dict((v,k) for k, v in statusMap.iteritems())
translatedStatusMap = {} # -> CollectorModel.__init__
+def formatSize(size):
+ """formats size of bytes"""
+ size = int(size)
+ steps = 0
+ sizes = ["B", "KiB", "MiB", "GiB", "TiB"]
+
+ while size > 1000:
+ size /= 1024.0
+ steps += 1
+
+ return "%.2f %s" % (size, sizes[steps])
+
class CollectorModel(QAbstractItemModel):
def __init__(self, view, connector):
QAbstractItemModel.__init__(self)
self.connector = connector
self.view = view
self._data = []
- self.cols = 3
+ self.cols = 4
self.interval = 1
self.mutex = QMutex()
@@ -161,6 +173,16 @@ class CollectorModel(QAbstractItemModel):
if role == Qt.DisplayRole:
if index.column() == 0:
return QVariant(index.internalPointer().data["name"])
+ elif index.column() == 1:
+ item = index.internalPointer()
+ plugins = []
+ if isinstance(item, Package):
+ for child in item.children:
+ if not child.data["plugin"] in plugins:
+ plugins.append(child.data["plugin"])
+ else:
+ plugins.append(item.data["plugin"])
+ return QVariant(", ".join(plugins))
elif index.column() == 2:
item = index.internalPointer()
status = 0
@@ -171,16 +193,15 @@ class CollectorModel(QAbstractItemModel):
else:
status = item.data["status"]
return QVariant(self.translateStatus(statusMapReverse[status]))
- elif index.column() == 1:
+ elif index.column() == 3:
item = index.internalPointer()
- plugins = []
- if isinstance(item, Package):
- for child in item.children:
- if not child.data["plugin"] in plugins:
- plugins.append(child.data["plugin"])
+ if isinstance(item, Link):
+ return QVariant(formatSize(item.data["size"]))
else:
- plugins.append(item.data["plugin"])
- return QVariant(", ".join(plugins))
+ ms = 0
+ for c in item.children:
+ ms += c.data["size"]
+ return QVariant(formatSize(ms))
elif role == Qt.EditRole:
if index.column() == 0:
return QVariant(index.internalPointer().data["name"])
@@ -244,10 +265,12 @@ class CollectorModel(QAbstractItemModel):
if orientation == Qt.Horizontal and role == Qt.DisplayRole:
if section == 0:
return QVariant(_("Name"))
- elif section == 2:
- return QVariant(_("Status"))
elif section == 1:
return QVariant(_("Plugin"))
+ elif section == 2:
+ return QVariant(_("Status"))
+ elif section == 3:
+ return QVariant(_("Size"))
return QVariant()
def flags(self, index):
@@ -331,6 +354,7 @@ class CollectorView(QTreeView):
self.setColumnWidth(0, 500)
self.setColumnWidth(1, 100)
self.setColumnWidth(2, 200)
+ self.setColumnWidth(3, 100)
self.setEditTriggers(QAbstractItemView.DoubleClicked | QAbstractItemView.EditKeyPressed)
diff --git a/module/gui/Queue.py b/module/gui/Queue.py
index 977dd6e9a..94025c867 100644
--- a/module/gui/Queue.py
+++ b/module/gui/Queue.py
@@ -23,19 +23,7 @@ from module.remote.thriftbackend.thriftgen.pyload.ttypes import *
from time import sleep, time
-from module.gui.Collector import CollectorModel, Package, Link, CollectorView, statusMap, statusMapReverse
-
-def formatSize(size):
- """formats size of bytes"""
- size = int(size)
- steps = 0
- sizes = ["B", "KiB", "MiB", "GiB", "TiB"]
-
- while size > 1000:
- size /= 1024.0
- steps += 1
-
- return "%.2f %s" % (size, sizes[steps])
+from module.gui.Collector import CollectorModel, Package, Link, CollectorView, statusMap, statusMapReverse, formatSize
def formatSpeed(speed):
speed = int(speed)
diff --git a/module/remote/thriftbackend/Handler.py b/module/remote/thriftbackend/Handler.py
index 6e1377938..91848941b 100644
--- a/module/remote/thriftbackend/Handler.py
+++ b/module/remote/thriftbackend/Handler.py
@@ -191,7 +191,11 @@ class Handler(Iface):
Parameters:
- fid
"""
- rawData = self.serverMethods.get_file_data(fid).values()[0]
+ rawData = self.serverMethods.get_file_data(fid)
+ if rawData:
+ rawData = rawData.values()[0]
+ else:
+ return None
fdata = self._convertPyFile(rawData)
return fdata
@@ -372,7 +376,7 @@ class Handler(Iface):
packs = self.serverMethods.get_collector()
for pid in packs:
pack = self.serverMethods.get_package_data(pid)
- while pack["order"] in order.keys():
+ while pack["order"] in order.keys(): #just in case
pack["order"] += 1
order[pack["order"]] = pack["id"]
return order
@@ -385,6 +389,8 @@ class Handler(Iface):
rawData = self.serverMethods.get_package_data(pid)
order = {}
for pyfile in rawData["links"]:
+ while pyfile["order"] in order.keys(): #just in case
+ pyfile["order"] += 1
order[pyfile["order"]] = pyfile["id"]
return order