From 56a97ec93598f3afdc37e9fece8eb045de5f4a22 Mon Sep 17 00:00:00 2001 From: Arno Date: Tue, 19 Dec 2017 07:08:32 +0100 Subject: Don't gatherData() when deleting torrents Just as before: delete the files and remove them from the view without a full parse. --- torrentwidget.cpp | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/torrentwidget.cpp b/torrentwidget.cpp index 7f88eef..f93115b 100644 --- a/torrentwidget.cpp +++ b/torrentwidget.cpp @@ -223,9 +223,10 @@ void TorrentWidget::deleteFiles(){ } QString q = QString(tr("Really delete %1 file(s)?")).arg(QString::number(sel.count())); int res = QMessageBox::question(this, tr("Delete files..."), q); - int ctr = 0; if(res == QMessageBox::Yes){ - foreach(QModelIndex i, sel){ + int ctr = 0; + QStringList removed; + for(const QModelIndex &i : sel){ QString fp = i.data(FullPathRole).toString(); bool ok = QFile::remove(fp); if(ok){ @@ -235,10 +236,16 @@ void TorrentWidget::deleteFiles(){ QString msg = QString(tr("Shit: %1 vanished from under us!")).arg(fi.fileName()); QMessageBox::critical(this, tr("Error"), msg); } + removed << i.data().toString(); + } + for(const QString& f : removed){ + QList res = mModel->findItems(f, Qt::MatchExactly, NameColumn); + if(!res.isEmpty()){ + mModel->removeRow(res.at(0)->row()); + } } QString msg = QString(tr("Successfully deleted %1 of %2 file(s)")).arg(QString::number(ctr)).arg(QString::number(sel.count())); emit statusMessage(msg); - gatherData(); emit freeSpaceChanged(mDir->text()); } } -- cgit v1.2.3-70-g09d2