diff options
-rw-r--r-- | pyLoadQtGui.py | 467 |
1 files changed, 48 insertions, 419 deletions
diff --git a/pyLoadQtGui.py b/pyLoadQtGui.py index ad4fd1d0b..b3f206bd1 100644 --- a/pyLoadQtGui.py +++ b/pyLoadQtGui.py @@ -110,14 +110,16 @@ class main(QObject): self.mainWindow.tabs["queue"]["view"].setup() model.startLoop() """ - self.mainWindow.tabs["queue"]["view"].setColumnCount(3) - self.mainWindow.tabs["queue"]["view"].setHeaderLabels(["Name", "Status", "Fortschritt"]) - self.mainWindow.tabs["queue"]["view"].setColumnWidth(0, 300) - self.mainWindow.tabs["queue"]["view"].setColumnWidth(1, 100) - self.mainWindow.tabs["queue"]["view"].setColumnWidth(2, 100) - #delegate = QueueProgressBarDelegate(self) - #self.mainWindow.tabs["queue"]["view"].setItemDelegateForColumn(2, delegate) - self.queue = Queue(self.mainWindow.tabs["queue"]["view"], self.connector) + view = self.mainWindow.tabs["queue"]["view"] + view.setColumnCount(3) + view.setHeaderLabels(["Name", "Status", "Fortschritt"]) + view.setColumnWidth(0, 300) + view.setColumnWidth(1, 100) + view.setColumnWidth(2, 100) + self.queue = Queue(view, self.connector) + delegate = QueueProgressBarDelegate(view, self.queue) + view.setItemDelegateForColumn(2, delegate) + #view.setup(self.queue) self.queue.start() class connector(QThread): @@ -325,7 +327,7 @@ class Queue(QThread): def update(self): locker = QMutexLocker(self.mutex) packs = self.connector.getPackageQueue() - downloading = self.connector.getDownloadQueue() + self.downloading = self.connector.getDownloadQueue() for data in packs: pack = self.getPack(data["id"]) if not pack: @@ -366,6 +368,7 @@ class Queue(QThread): if status >= 0: item.setData(1, Qt.DisplayRole, QVariant(self.statusMapReverse[status])) item.setData(0, Qt.UserRole, QVariant(pid)) + item.setData(2, Qt.UserRole, QVariant(newPack)) def getPack(self, pid): for k, pack in enumerate(self.queue): @@ -373,6 +376,36 @@ class Queue(QThread): return pack return None + def getProgress(self, q): + locker = QMutexLocker(self.mutex) + if isinstance(q, self.QueueFile): + for d in self.downloading: + if d["id"] == q.getData()["id"]: + return int(d["percent"]) + if q.data["status_type"] == "finished" or \ + q.data["status_type"] == "failed" or \ + q.data["status_type"] == "aborted": + return 100 + elif isinstance(q, self.QueuePack): + children = q.getChildren() + count = len(children) + perc_sum = 0 + for child in children: + val = 0 + for d in self.downloading: + if d["id"] == child.getData()["id"]: + val = int(d["percent"]) + break + if child.data["status_type"] == "finished" or \ + child.data["status_type"] == "failed" or \ + child.data["status_type"] == "aborted": + val = 100 + perc_sum += val + if count == 0: + return None + return perc_sum/count + return None + class QueuePack(): def __init__(self, queue): self.queue = queue @@ -401,6 +434,7 @@ class Queue(QThread): item.setData(0, Qt.DisplayRole, QVariant(newChild.getData()["filename"])) item.setData(1, Qt.DisplayRole, QVariant(newChild.getData()["status_type"])) item.setData(0, Qt.UserRole, QVariant(cid)) + item.setData(2, Qt.UserRole, QVariant(newChild)) def getChildren(self): return self.children @@ -434,420 +468,15 @@ class Queue(QThread): def getPack(self): return self.pack - """ - def data(self, index, role=Qt.DisplayRole): - locker = QMutexLocker(self.mutex) - if not index.isValid(): - return QVariant() - if role == Qt.DisplayRole: - q = self.nodeFromIndex(index) - if index.column() == 0: - if isinstance(q, QueuePack): - return QVariant(q.data["package_name"]) - else: - return QVariant(q.data["filename"]) - elif index.column() == 1: - if isinstance(q, QueueFile): - return QVariant(q.data["status_type"]) - else: - status = 0 - for child in q.getChildren(): - if self.statusMap.has_key(child.data["status_type"]) and self.statusMap[child.data["status_type"]] > status: - status = self.statusMap[child.data["status_type"]] - return QVariant(self.statusMapReverse[status]) - return QVariant() - - - packs = self.connector.getPackageQueue() - for data in packs: - 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) - - - self.mutex.lock() - packs = self.connector.getPackageQueue() - self.downloading = self.connector.getDownloadQueue() - previous = None - for data in packs: - pos = self._inQueue(data["id"]) - if not type(pos) == int: - pack = QueuePack(data) - else: - pack = QueuePack(data) - #self.mutex.lock() - self.queue[pos] = pack - #self.mutex.unlock() - if not type(pos) == int: - self.mutex.unlock() - self._insertPack(pack, previous) - self.mutex.lock() - files = self.connector.getPackageFiles(data["id"]) - pos = self._inQueue(data["id"]) - for fid in files: - info = self.connector.getLinkInfo(fid) - qFile = QueueFile(info, pack) - if type(pos) == int: - self.mutex.unlock() - index = self.index(pos, 0) - pack.addChild(qFile, self, index) - self.mutex.lock() - previous = pack.getID() - self.mutex.unlock() - - - - - - - -class QueueFile(): - def __init__(self, data, pack): - self.mutex = QMutex() - self.mutex.lock() - self.pack = pack - self.mutex.unlock() - self.update(data) - - def update(self, data): - self.mutex.lock() - self.data = data - self.mutex.unlock() - - def getID(self): - self.mutex.lock() - id = self.data["id"] - self.mutex.unlock() - return id - -class QueuePack(): - def __init__(self, data): - self.mutex = QMutex() - self.mutex.lock() - self.data = data - self.children = [] - self.mutex.unlock() - - def update(self, data): - self.mutex.lock() - self.data = data - self.mutex.unlock() - - def addChild(self, NewQFile, model, index): - self.mutex.lock() - for k, QFile in enumerate(self.children): - if QFile.getID() == NewQFile.getID(): - QFile.update(NewQFile.data) - #model.emit(SIGNAL("dataChanged(const QModelIndex &, const QModelIndex &)"), model.index(k, 0, index), model.index(k, 2, index)) - return - self.mutex.unlock() - model.beginInsertRows(index, len(self.children), len(self.children)+1) - self.mutex.lock() - self.children.append(NewQFile) - self.mutex.unlock() - model.endInsertRows() - - def getChildren(self): - self.mutex.lock() - children = self.children - self.mutex.unlock() - return children - - def getID(self): - self.mutex.lock() - id = self.data["id"] - self.mutex.unlock() - return id - -class MyLock(QMutex): - def __init__(self): - QMutex.__init__(self) - - def lock(self): - QMutex.lock(self) - print "locked" - - def unlock(self): - QMutex.unlock(self) - print "unlocked" - -class QueueModel(QAbstractItemModel): - def __init__(self, connector): - QAbstractItemModel.__init__(self) - self.mutex = MyLock() - #self.mutex.lock() - self.connector = connector - self.queue = [] - self.downloading = [] - self.statusMap = { - "finished": 0, - "checking": 1, - "waiting": 2, - "reconnected": 3, - "downloading": 4, - "failed": 5, - "aborted": 6, - } - self.statusMapReverse = dict((v,k) for k, v in self.statusMap.iteritems()) - self.cols = 3 - self.interval = 1 - self.view = None - #self.mutex.unlock() - self.update() - self.loop = self.Loop(self) - self.connect(self, SIGNAL("updateData()"), self.update) - - def setView(self, view): - self.mutex.lock() - self.view = view - self.mutex.unlock() - - def _update(self): - self.mutex.lock() - packs = self.connector.getPackageQueue() - self.downloading = self.connector.getDownloadQueue() - previous = None - for data in packs: - pos = self._inQueue(data["id"]) - if not type(pos) == int: - pack = QueuePack(data) - else: - pack = QueuePack(data) - #self.mutex.lock() - self.queue[pos] = pack - #self.mutex.unlock() - if not type(pos) == int: - self.mutex.unlock() - self._insertPack(pack, previous) - self.mutex.lock() - files = self.connector.getPackageFiles(data["id"]) - pos = self._inQueue(data["id"]) - for fid in files: - info = self.connector.getLinkInfo(fid) - qFile = QueueFile(info, pack) - if type(pos) == int: - self.mutex.unlock() - index = self.index(pos, 0) - pack.addChild(qFile, self, index) - self.mutex.lock() - previous = pack.getID() - self.mutex.unlock() - - def update(self): - #locker = QMutexLocker(self.mutex) - print "updating" - #self.mutex.lock() - #locker.unlock() - self._update() - self.emit(SIGNAL("dataChanged(const QModelIndex &, const QModelIndex &)"), self.index(0, 0), self.index(self.rowCount()-1, 2)) - #locker.relock() - #self.mutex.unlock() - #if self.view: - # self.view.emit(SIGNAL("update()")) - print "done" - - def startLoop(self): - self.loop.start() - - def _inQueue(self, pid): - for k, pack in enumerate(self.queue): - if pack.getID() == pid: - return k - return False - - def _insertPack(self, newpack, prevID): - self.mutex.lock() - ck = 0 - for k, pack in enumerate(self.queue): - ck = k - if pack.getID() == prevID: - break - self.mutex.unlock() - #self.mutex.unlock() - self.beginInsertRows(QModelIndex(),ck+1, ck+2) - self.mutex.lock() - self.queue.insert(ck+1, newpack) - self.mutex.unlock() - self.endInsertRows() - #self.mutex.lock() - - def index(self, row, column, parent=QModelIndex()): - self.mutex.lock() - if parent == QModelIndex(): - pointer = self.queue[row] - index = self.createIndex(row, column, pointer) - elif parent.isValid(): - q = self.nodeFromIndex(parent) - #self.mutex.lock() - pointer = q.getChildren()[row] - #self.mutex.unlock() - index = self.createIndex(row, column, pointer) - else: - index = QModelIndex() - self.mutex.unlock() - return index - - def nodeFromIndex(self, index): - if index.isValid(): - return index.internalPointer() - else: - return None - - def parent(self, index): - locker = QMutexLocker(self.mutex) - if index == QModelIndex(): - return QModelIndex() - if index.isValid(): - q = self.nodeFromIndex(index) - if isinstance(q, QueueFile): - row = None - for k, pack in enumerate(self.queue): - if pack.getID() == q.pack.getID(): - row = k - if row != None: - return self.createIndex(row, 0, q.pack) - return QModelIndex() - - def rowCount(self, parent=QModelIndex()): - locker = QMutexLocker(self.mutex) - if parent == QModelIndex(): - #return package count - qlen = len(self.queue) - return qlen - else: - if parent.isValid(): - #index is valid - q = self.nodeFromIndex(parent) - if isinstance(q, QueuePack): - #index points to a package - #return len of children - clen = len(q.getChildren()) - return clen - else: - #index is invalid - return False - #files have no children - return 0 - - def columnCount(self, parent=QModelIndex()): - #self.mutex.lock() - return self.cols - #self.mutex.unlock() - - def data(self, index, role=Qt.DisplayRole): - locker = QMutexLocker(self.mutex) - if not index.isValid(): - return QVariant() - if role == Qt.DisplayRole: - q = self.nodeFromIndex(index) - if index.column() == 0: - if isinstance(q, QueuePack): - return QVariant(q.data["package_name"]) - else: - return QVariant(q.data["filename"]) - elif index.column() == 1: - if isinstance(q, QueueFile): - return QVariant(q.data["status_type"]) - else: - status = 0 - for child in q.getChildren(): - if self.statusMap.has_key(child.data["status_type"]) and self.statusMap[child.data["status_type"]] > status: - status = self.statusMap[child.data["status_type"]] - return QVariant(self.statusMapReverse[status]) - return QVariant() - - def hasChildren(self, parent=QModelIndex()): - self.mutex.lock() - if not parent.isValid(): - self.mutex.unlock() - return True - self.mutex.unlock() - return (self.rowCount(parent) > 0) - - def canFetchMore(self, parent): - return False - - def headerData(self, section, orientation, role=Qt.DisplayRole): - if orientation == Qt.Horizontal and role == Qt.DisplayRole: - if section == 0: - return QVariant("Name") - elif section == 1: - return QVariant("Status") - elif section == 2: - return QVariant("Fortschritt") - return QVariant() - - def getProgress(self, index): - locker = QMutexLocker(self.mutex) - q = self.nodeFromIndex(index) - if isinstance(q, QueueFile): - for d in self.downloading: - if d["id"] == q.getID(): - return int(d["percent"]) - if q.data["status_type"] == "finished" or \ - q.data["status_type"] == "failed" or \ - q.data["status_type"] == "aborted": - return 100 - elif isinstance(q, QueuePack): - children = q.getChildren() - count = len(children) - perc_sum = 0 - for child in children: - val = 0 - for d in self.downloading: - if d["id"] == child.getID(): - val = int(d["percent"]) - break - if child.data["status_type"] == "finished" or \ - child.data["status_type"] == "failed" or \ - child.data["status_type"] == "aborted": - val = 100 - perc_sum += val - if count == 0: - return None - return perc_sum/count - return None - - class Loop(QThread): - def __init__(self, model): - QThread.__init__(self) - self.model = model - self.running = True - - def run(self): - while self.running: - sleep(self.model.interval) - #self.model.update() - #print "emit" - self.model.emit(SIGNAL("updateData()")) - -class QueueView(QTreeView): - def __init__(self): - QTreeView.__init__(self) - - def setup(self): - self.setColumnWidth(0, 300) - self.setColumnWidth(1, 100) - self.setColumnWidth(2, 100) - delegate = QueueProgressBarDelegate(self) - self.setItemDelegateForColumn(2, delegate) - """ - class QueueProgressBarDelegate(QItemDelegate): - def __init__(self, parent): + def __init__(self, parent, queue): QItemDelegate.__init__(self, parent) + self.queue = queue def paint(self, painter, option, index): if index.column() == 2: - model = index.model() - progress = model.getProgress(index) + qe = index.data(Qt.UserRole).toPyObject() + progress = self.queue.getProgress(qe) if progress == None: QItemDelegate.paint(self, painter, option, index) return @@ -863,7 +492,7 @@ class QueueProgressBarDelegate(QItemDelegate): opts.text = QString.number(opts.progress) + "%" QApplication.style().drawControl(QStyle.CE_ProgressBar, opts, painter) return - QItemDelegate.paint(painter, option, index) + QItemDelegate.paint(self, painter, option, index) if __name__ == "__main__": app = main() |