mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 21:14:33 +00:00
Merge pull request #14520 from glassez/save-resume
Improve "save resume data" handling
This commit is contained in:
commit
7a26a92edd
@ -1984,6 +1984,25 @@ void Session::bottomTorrentsQueuePos(const QVector<TorrentID> &ids)
|
|||||||
saveTorrentsQueue();
|
saveTorrentsQueue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Session::handleTorrentNeedSaveResumeData(const TorrentImpl *torrent)
|
||||||
|
{
|
||||||
|
if (m_needSaveResumeDataTorrents.empty())
|
||||||
|
{
|
||||||
|
QMetaObject::invokeMethod(this, [this]()
|
||||||
|
{
|
||||||
|
for (const TorrentID &torrentID : asConst(m_needSaveResumeDataTorrents))
|
||||||
|
{
|
||||||
|
TorrentImpl *torrent = m_torrents.value(torrentID);
|
||||||
|
if (torrent)
|
||||||
|
torrent->saveResumeData();
|
||||||
|
}
|
||||||
|
m_needSaveResumeDataTorrents.clear();
|
||||||
|
}, Qt::QueuedConnection);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_needSaveResumeDataTorrents.insert(torrent->id());
|
||||||
|
}
|
||||||
|
|
||||||
void Session::handleTorrentSaveResumeDataRequested(const TorrentImpl *torrent)
|
void Session::handleTorrentSaveResumeDataRequested(const TorrentImpl *torrent)
|
||||||
{
|
{
|
||||||
qDebug("Saving resume data is requested for torrent '%s'...", qUtf8Printable(torrent->name()));
|
qDebug("Saving resume data is requested for torrent '%s'...", qUtf8Printable(torrent->name()));
|
||||||
@ -2317,7 +2336,10 @@ void Session::generateResumeData()
|
|||||||
if (!torrent->isValid()) continue;
|
if (!torrent->isValid()) continue;
|
||||||
|
|
||||||
if (torrent->needSaveResumeData())
|
if (torrent->needSaveResumeData())
|
||||||
|
{
|
||||||
torrent->saveResumeData();
|
torrent->saveResumeData();
|
||||||
|
m_needSaveResumeDataTorrents.remove(torrent->id());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3761,49 +3783,41 @@ void Session::updateSeedingLimitTimer()
|
|||||||
|
|
||||||
void Session::handleTorrentShareLimitChanged(TorrentImpl *const torrent)
|
void Session::handleTorrentShareLimitChanged(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
updateSeedingLimitTimer();
|
updateSeedingLimitTimer();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentNameChanged(TorrentImpl *const torrent)
|
void Session::handleTorrentNameChanged(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
Q_UNUSED(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentSavePathChanged(TorrentImpl *const torrent)
|
void Session::handleTorrentSavePathChanged(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentSavePathChanged(torrent);
|
emit torrentSavePathChanged(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentCategoryChanged(TorrentImpl *const torrent, const QString &oldCategory)
|
void Session::handleTorrentCategoryChanged(TorrentImpl *const torrent, const QString &oldCategory)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentCategoryChanged(torrent, oldCategory);
|
emit torrentCategoryChanged(torrent, oldCategory);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentTagAdded(TorrentImpl *const torrent, const QString &tag)
|
void Session::handleTorrentTagAdded(TorrentImpl *const torrent, const QString &tag)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentTagAdded(torrent, tag);
|
emit torrentTagAdded(torrent, tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentTagRemoved(TorrentImpl *const torrent, const QString &tag)
|
void Session::handleTorrentTagRemoved(TorrentImpl *const torrent, const QString &tag)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentTagRemoved(torrent, tag);
|
emit torrentTagRemoved(torrent, tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentSavingModeChanged(TorrentImpl *const torrent)
|
void Session::handleTorrentSavingModeChanged(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentSavingModeChanged(torrent);
|
emit torrentSavingModeChanged(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentTrackersAdded(TorrentImpl *const torrent, const QVector<TrackerEntry> &newTrackers)
|
void Session::handleTorrentTrackersAdded(TorrentImpl *const torrent, const QVector<TrackerEntry> &newTrackers)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
|
|
||||||
for (const TrackerEntry &newTracker : newTrackers)
|
for (const TrackerEntry &newTracker : newTrackers)
|
||||||
LogMsg(tr("Tracker '%1' was added to torrent '%2'").arg(newTracker.url, torrent->name()));
|
LogMsg(tr("Tracker '%1' was added to torrent '%2'").arg(newTracker.url, torrent->name()));
|
||||||
emit trackersAdded(torrent, newTrackers);
|
emit trackersAdded(torrent, newTrackers);
|
||||||
@ -3814,8 +3828,6 @@ void Session::handleTorrentTrackersAdded(TorrentImpl *const torrent, const QVect
|
|||||||
|
|
||||||
void Session::handleTorrentTrackersRemoved(TorrentImpl *const torrent, const QVector<TrackerEntry> &deletedTrackers)
|
void Session::handleTorrentTrackersRemoved(TorrentImpl *const torrent, const QVector<TrackerEntry> &deletedTrackers)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
|
|
||||||
for (const TrackerEntry &deletedTracker : deletedTrackers)
|
for (const TrackerEntry &deletedTracker : deletedTrackers)
|
||||||
LogMsg(tr("Tracker '%1' was deleted from torrent '%2'").arg(deletedTracker.url, torrent->name()));
|
LogMsg(tr("Tracker '%1' was deleted from torrent '%2'").arg(deletedTracker.url, torrent->name()));
|
||||||
emit trackersRemoved(torrent, deletedTrackers);
|
emit trackersRemoved(torrent, deletedTrackers);
|
||||||
@ -3826,20 +3838,17 @@ void Session::handleTorrentTrackersRemoved(TorrentImpl *const torrent, const QVe
|
|||||||
|
|
||||||
void Session::handleTorrentTrackersChanged(TorrentImpl *const torrent)
|
void Session::handleTorrentTrackersChanged(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit trackersChanged(torrent);
|
emit trackersChanged(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentUrlSeedsAdded(TorrentImpl *const torrent, const QVector<QUrl> &newUrlSeeds)
|
void Session::handleTorrentUrlSeedsAdded(TorrentImpl *const torrent, const QVector<QUrl> &newUrlSeeds)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
for (const QUrl &newUrlSeed : newUrlSeeds)
|
for (const QUrl &newUrlSeed : newUrlSeeds)
|
||||||
LogMsg(tr("URL seed '%1' was added to torrent '%2'").arg(newUrlSeed.toString(), torrent->name()));
|
LogMsg(tr("URL seed '%1' was added to torrent '%2'").arg(newUrlSeed.toString(), torrent->name()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentUrlSeedsRemoved(TorrentImpl *const torrent, const QVector<QUrl> &urlSeeds)
|
void Session::handleTorrentUrlSeedsRemoved(TorrentImpl *const torrent, const QVector<QUrl> &urlSeeds)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
for (const QUrl &urlSeed : urlSeeds)
|
for (const QUrl &urlSeed : urlSeeds)
|
||||||
LogMsg(tr("URL seed '%1' was removed from torrent '%2'").arg(urlSeed.toString(), torrent->name()));
|
LogMsg(tr("URL seed '%1' was removed from torrent '%2'").arg(urlSeed.toString(), torrent->name()));
|
||||||
}
|
}
|
||||||
@ -3867,13 +3876,11 @@ void Session::handleTorrentMetadataReceived(TorrentImpl *const torrent)
|
|||||||
|
|
||||||
void Session::handleTorrentPaused(TorrentImpl *const torrent)
|
void Session::handleTorrentPaused(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentPaused(torrent);
|
emit torrentPaused(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::handleTorrentResumed(TorrentImpl *const torrent)
|
void Session::handleTorrentResumed(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentResumed(torrent);
|
emit torrentResumed(torrent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3884,8 +3891,6 @@ void Session::handleTorrentChecked(TorrentImpl *const torrent)
|
|||||||
|
|
||||||
void Session::handleTorrentFinished(TorrentImpl *const torrent)
|
void Session::handleTorrentFinished(TorrentImpl *const torrent)
|
||||||
{
|
{
|
||||||
if (!torrent->hasError() && !torrent->hasMissingFiles())
|
|
||||||
torrent->saveResumeData();
|
|
||||||
emit torrentFinished(torrent);
|
emit torrentFinished(torrent);
|
||||||
|
|
||||||
qDebug("Checking if the torrent contains torrent files to download");
|
qDebug("Checking if the torrent contains torrent files to download");
|
||||||
|
@ -465,6 +465,7 @@ namespace BitTorrent
|
|||||||
void bottomTorrentsQueuePos(const QVector<TorrentID> &ids);
|
void bottomTorrentsQueuePos(const QVector<TorrentID> &ids);
|
||||||
|
|
||||||
// Torrent interface
|
// Torrent interface
|
||||||
|
void handleTorrentNeedSaveResumeData(const TorrentImpl *torrent);
|
||||||
void handleTorrentSaveResumeDataRequested(const TorrentImpl *torrent);
|
void handleTorrentSaveResumeDataRequested(const TorrentImpl *torrent);
|
||||||
void handleTorrentShareLimitChanged(TorrentImpl *const torrent);
|
void handleTorrentShareLimitChanged(TorrentImpl *const torrent);
|
||||||
void handleTorrentNameChanged(TorrentImpl *const torrent);
|
void handleTorrentNameChanged(TorrentImpl *const torrent);
|
||||||
@ -770,6 +771,7 @@ namespace BitTorrent
|
|||||||
QHash<TorrentID, LoadTorrentParams> m_loadingTorrents;
|
QHash<TorrentID, LoadTorrentParams> m_loadingTorrents;
|
||||||
QHash<QString, AddTorrentParams> m_downloadedTorrents;
|
QHash<QString, AddTorrentParams> m_downloadedTorrents;
|
||||||
QHash<TorrentID, RemovingTorrentData> m_removingTorrents;
|
QHash<TorrentID, RemovingTorrentData> m_removingTorrents;
|
||||||
|
QSet<TorrentID> m_needSaveResumeDataTorrents;
|
||||||
QStringMap m_categories;
|
QStringMap m_categories;
|
||||||
QSet<QString> m_tags;
|
QSet<QString> m_tags;
|
||||||
|
|
||||||
|
@ -424,6 +424,7 @@ void TorrentImpl::setAutoTMMEnabled(bool enabled)
|
|||||||
if (m_useAutoTMM == enabled) return;
|
if (m_useAutoTMM == enabled) return;
|
||||||
|
|
||||||
m_useAutoTMM = enabled;
|
m_useAutoTMM = enabled;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentSavingModeChanged(this);
|
m_session->handleTorrentSavingModeChanged(this);
|
||||||
|
|
||||||
if (m_useAutoTMM)
|
if (m_useAutoTMM)
|
||||||
@ -484,7 +485,10 @@ void TorrentImpl::addTrackers(const QVector<TrackerEntry> &trackers)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!newTrackers.isEmpty())
|
if (!newTrackers.isEmpty())
|
||||||
|
{
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentTrackersAdded(this, newTrackers);
|
m_session->handleTorrentTrackersAdded(this, newTrackers);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::replaceTrackers(const QVector<TrackerEntry> &trackers)
|
void TorrentImpl::replaceTrackers(const QVector<TrackerEntry> &trackers)
|
||||||
@ -507,6 +511,8 @@ void TorrentImpl::replaceTrackers(const QVector<TrackerEntry> &trackers)
|
|||||||
|
|
||||||
m_nativeHandle.replace_trackers(nativeTrackers);
|
m_nativeHandle.replace_trackers(nativeTrackers);
|
||||||
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
|
|
||||||
if (newTrackers.isEmpty() && currentTrackers.isEmpty())
|
if (newTrackers.isEmpty() && currentTrackers.isEmpty())
|
||||||
{
|
{
|
||||||
// when existing tracker reorders
|
// when existing tracker reorders
|
||||||
@ -558,7 +564,10 @@ void TorrentImpl::addUrlSeeds(const QVector<QUrl> &urlSeeds)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!addedUrlSeeds.isEmpty())
|
if (!addedUrlSeeds.isEmpty())
|
||||||
|
{
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentUrlSeedsAdded(this, addedUrlSeeds);
|
m_session->handleTorrentUrlSeedsAdded(this, addedUrlSeeds);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::removeUrlSeeds(const QVector<QUrl> &urlSeeds)
|
void TorrentImpl::removeUrlSeeds(const QVector<QUrl> &urlSeeds)
|
||||||
@ -579,7 +588,10 @@ void TorrentImpl::removeUrlSeeds(const QVector<QUrl> &urlSeeds)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!removedUrlSeeds.isEmpty())
|
if (!removedUrlSeeds.isEmpty())
|
||||||
|
{
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentUrlSeedsRemoved(this, removedUrlSeeds);
|
m_session->handleTorrentUrlSeedsRemoved(this, removedUrlSeeds);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::clearPeers()
|
void TorrentImpl::clearPeers()
|
||||||
@ -611,9 +623,7 @@ bool TorrentImpl::connectPeer(const PeerAddress &peerAddress)
|
|||||||
|
|
||||||
bool TorrentImpl::needSaveResumeData() const
|
bool TorrentImpl::needSaveResumeData() const
|
||||||
{
|
{
|
||||||
if (m_isStopped && !(m_nativeStatus.flags & lt::torrent_flags::auto_managed))
|
return m_nativeHandle.need_save_resume_data();
|
||||||
return false;
|
|
||||||
return m_nativeStatus.need_save_resume;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::saveResumeData()
|
void TorrentImpl::saveResumeData()
|
||||||
@ -692,6 +702,7 @@ bool TorrentImpl::addTag(const QString &tag)
|
|||||||
if (!m_session->addTag(tag))
|
if (!m_session->addTag(tag))
|
||||||
return false;
|
return false;
|
||||||
m_tags.insert(tag);
|
m_tags.insert(tag);
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentTagAdded(this, tag);
|
m_session->handleTorrentTagAdded(this, tag);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -702,6 +713,7 @@ bool TorrentImpl::removeTag(const QString &tag)
|
|||||||
{
|
{
|
||||||
if (m_tags.remove(tag))
|
if (m_tags.remove(tag))
|
||||||
{
|
{
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentTagRemoved(this, tag);
|
m_session->handleTorrentTagRemoved(this, tag);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1292,6 +1304,7 @@ void TorrentImpl::setName(const QString &name)
|
|||||||
if (m_name != name)
|
if (m_name != name)
|
||||||
{
|
{
|
||||||
m_name = name;
|
m_name = name;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentNameChanged(this);
|
m_session->handleTorrentNameChanged(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1305,6 +1318,7 @@ bool TorrentImpl::setCategory(const QString &category)
|
|||||||
|
|
||||||
const QString oldCategory = m_category;
|
const QString oldCategory = m_category;
|
||||||
m_category = category;
|
m_category = category;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentCategoryChanged(this, oldCategory);
|
m_session->handleTorrentCategoryChanged(this, oldCategory);
|
||||||
|
|
||||||
if (m_useAutoTMM)
|
if (m_useAutoTMM)
|
||||||
@ -1324,6 +1338,7 @@ void TorrentImpl::move(QString path)
|
|||||||
if (m_useAutoTMM)
|
if (m_useAutoTMM)
|
||||||
{
|
{
|
||||||
m_useAutoTMM = false;
|
m_useAutoTMM = false;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentSavingModeChanged(this);
|
m_session->handleTorrentSavingModeChanged(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1339,8 +1354,8 @@ void TorrentImpl::move(QString path)
|
|||||||
void TorrentImpl::move_impl(QString path, const MoveStorageMode mode)
|
void TorrentImpl::move_impl(QString path, const MoveStorageMode mode)
|
||||||
{
|
{
|
||||||
if (path == savePath()) return;
|
if (path == savePath()) return;
|
||||||
path = Utils::Fs::toNativePath(path);
|
|
||||||
|
|
||||||
|
path = Utils::Fs::toNativePath(path);
|
||||||
if (!useTempPath())
|
if (!useTempPath())
|
||||||
{
|
{
|
||||||
moveStorage(path, mode);
|
moveStorage(path, mode);
|
||||||
@ -1348,6 +1363,7 @@ void TorrentImpl::move_impl(QString path, const MoveStorageMode mode)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_savePath = path;
|
m_savePath = path;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentSavePathChanged(this);
|
m_session->handleTorrentSavePathChanged(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1391,7 +1407,7 @@ void TorrentImpl::setSequentialDownload(const bool enable)
|
|||||||
m_nativeStatus.flags &= ~lt::torrent_flags::sequential_download; // prevent return cached value
|
m_nativeStatus.flags &= ~lt::torrent_flags::sequential_download; // prevent return cached value
|
||||||
}
|
}
|
||||||
|
|
||||||
saveResumeData();
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setFirstLastPiecePriority(const bool enabled)
|
void TorrentImpl::setFirstLastPiecePriority(const bool enabled)
|
||||||
@ -1406,7 +1422,7 @@ void TorrentImpl::setFirstLastPiecePriority(const bool enabled)
|
|||||||
LogMsg(tr("Download first and last piece first: %1, torrent: '%2'")
|
LogMsg(tr("Download first and last piece first: %1, torrent: '%2'")
|
||||||
.arg((enabled ? tr("On") : tr("Off")), name()));
|
.arg((enabled ? tr("On") : tr("Off")), name()));
|
||||||
|
|
||||||
saveResumeData();
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::applyFirstLastPiecePriority(const bool enabled, const QVector<DownloadPriority> &updatedFilePrio)
|
void TorrentImpl::applyFirstLastPiecePriority(const bool enabled, const QVector<DownloadPriority> &updatedFilePrio)
|
||||||
@ -1506,6 +1522,7 @@ void TorrentImpl::pause()
|
|||||||
if (!m_isStopped)
|
if (!m_isStopped)
|
||||||
{
|
{
|
||||||
m_isStopped = true;
|
m_isStopped = true;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentPaused(this);
|
m_session->handleTorrentPaused(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1542,6 +1559,7 @@ void TorrentImpl::resume(const TorrentOperatingMode mode)
|
|||||||
m_nativeHandle.unset_flags(lt::torrent_flags::stop_when_ready);
|
m_nativeHandle.unset_flags(lt::torrent_flags::stop_when_ready);
|
||||||
|
|
||||||
m_isStopped = false;
|
m_isStopped = false;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentResumed(this);
|
m_session->handleTorrentResumed(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1577,6 +1595,7 @@ void TorrentImpl::handleStateUpdate(const lt::torrent_status &nativeStatus)
|
|||||||
|
|
||||||
void TorrentImpl::handleMoveStorageJobFinished(const bool hasOutstandingJob)
|
void TorrentImpl::handleMoveStorageJobFinished(const bool hasOutstandingJob)
|
||||||
{
|
{
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_storageIsMoving = hasOutstandingJob;
|
m_storageIsMoving = hasOutstandingJob;
|
||||||
|
|
||||||
updateStatus();
|
updateStatus();
|
||||||
@ -1587,8 +1606,6 @@ void TorrentImpl::handleMoveStorageJobFinished(const bool hasOutstandingJob)
|
|||||||
m_session->handleTorrentSavePathChanged(this);
|
m_session->handleTorrentSavePathChanged(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
saveResumeData();
|
|
||||||
|
|
||||||
if (!m_storageIsMoving)
|
if (!m_storageIsMoving)
|
||||||
{
|
{
|
||||||
if (m_hasMissingFiles)
|
if (m_hasMissingFiles)
|
||||||
@ -1659,8 +1676,6 @@ void TorrentImpl::handleTorrentCheckedAlert(const lt::torrent_checked_alert *p)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
saveResumeData();
|
|
||||||
|
|
||||||
if (m_fastresumeDataRejected && !m_hasMissingFiles)
|
if (m_fastresumeDataRejected && !m_hasMissingFiles)
|
||||||
m_fastresumeDataRejected = false;
|
m_fastresumeDataRejected = false;
|
||||||
|
|
||||||
@ -1694,6 +1709,8 @@ void TorrentImpl::handleTorrentFinishedAlert(const lt::torrent_finished_alert *p
|
|||||||
adjustActualSavePath();
|
adjustActualSavePath();
|
||||||
manageIncompleteFiles();
|
manageIncompleteFiles();
|
||||||
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
|
|
||||||
const bool recheckTorrentsOnCompletion = Preferences::instance()->recheckTorrentsOnCompletion();
|
const bool recheckTorrentsOnCompletion = Preferences::instance()->recheckTorrentsOnCompletion();
|
||||||
if (isMoveInProgress() || (m_renameCount > 0))
|
if (isMoveInProgress() || (m_renameCount > 0))
|
||||||
{
|
{
|
||||||
@ -1870,8 +1887,7 @@ void TorrentImpl::handleFileRenamedAlert(const lt::file_renamed_alert *p)
|
|||||||
while (!isMoveInProgress() && (m_renameCount == 0) && !m_moveFinishedTriggers.isEmpty())
|
while (!isMoveInProgress() && (m_renameCount == 0) && !m_moveFinishedTriggers.isEmpty())
|
||||||
m_moveFinishedTriggers.takeFirst()();
|
m_moveFinishedTriggers.takeFirst()();
|
||||||
|
|
||||||
if (isPaused() && (m_renameCount == 0))
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
saveResumeData(); // otherwise the new path will not be saved
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::handleFileRenameFailedAlert(const lt::file_rename_failed_alert *p)
|
void TorrentImpl::handleFileRenameFailedAlert(const lt::file_rename_failed_alert *p)
|
||||||
@ -1888,8 +1904,7 @@ void TorrentImpl::handleFileRenameFailedAlert(const lt::file_rename_failed_alert
|
|||||||
while (!isMoveInProgress() && (m_renameCount == 0) && !m_moveFinishedTriggers.isEmpty())
|
while (!isMoveInProgress() && (m_renameCount == 0) && !m_moveFinishedTriggers.isEmpty())
|
||||||
m_moveFinishedTriggers.takeFirst()();
|
m_moveFinishedTriggers.takeFirst()();
|
||||||
|
|
||||||
if (isPaused() && (m_renameCount == 0))
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
saveResumeData(); // otherwise the new path will not be saved
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::handleFileCompletedAlert(const lt::file_completed_alert *p)
|
void TorrentImpl::handleFileCompletedAlert(const lt::file_completed_alert *p)
|
||||||
@ -1911,11 +1926,10 @@ void TorrentImpl::handleFileCompletedAlert(const lt::file_completed_alert *p)
|
|||||||
void TorrentImpl::handleMetadataReceivedAlert(const lt::metadata_received_alert *p)
|
void TorrentImpl::handleMetadataReceivedAlert(const lt::metadata_received_alert *p)
|
||||||
{
|
{
|
||||||
Q_UNUSED(p);
|
Q_UNUSED(p);
|
||||||
|
|
||||||
qDebug("Metadata received for torrent %s.", qUtf8Printable(name()));
|
qDebug("Metadata received for torrent %s.", qUtf8Printable(name()));
|
||||||
|
|
||||||
m_maintenanceJob = MaintenanceJob::HandleMetadata;
|
m_maintenanceJob = MaintenanceJob::HandleMetadata;
|
||||||
saveResumeData();
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::handlePerformanceAlert(const lt::performance_alert *p) const
|
void TorrentImpl::handlePerformanceAlert(const lt::performance_alert *p) const
|
||||||
@ -2113,6 +2127,7 @@ void TorrentImpl::setRatioLimit(qreal limit)
|
|||||||
if (m_ratioLimit != limit)
|
if (m_ratioLimit != limit)
|
||||||
{
|
{
|
||||||
m_ratioLimit = limit;
|
m_ratioLimit = limit;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentShareLimitChanged(this);
|
m_session->handleTorrentShareLimitChanged(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2127,6 +2142,7 @@ void TorrentImpl::setSeedingTimeLimit(int limit)
|
|||||||
if (m_seedingTimeLimit != limit)
|
if (m_seedingTimeLimit != limit)
|
||||||
{
|
{
|
||||||
m_seedingTimeLimit = limit;
|
m_seedingTimeLimit = limit;
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
m_session->handleTorrentShareLimitChanged(this);
|
m_session->handleTorrentShareLimitChanged(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2137,7 +2153,7 @@ void TorrentImpl::setUploadLimit(const int limit)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
m_nativeHandle.set_upload_limit(limit);
|
m_nativeHandle.set_upload_limit(limit);
|
||||||
saveResumeData();
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setDownloadLimit(const int limit)
|
void TorrentImpl::setDownloadLimit(const int limit)
|
||||||
@ -2146,7 +2162,7 @@ void TorrentImpl::setDownloadLimit(const int limit)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
m_nativeHandle.set_download_limit(limit);
|
m_nativeHandle.set_download_limit(limit);
|
||||||
saveResumeData();
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setSuperSeeding(const bool enable)
|
void TorrentImpl::setSuperSeeding(const bool enable)
|
||||||
@ -2158,7 +2174,8 @@ void TorrentImpl::setSuperSeeding(const bool enable)
|
|||||||
m_nativeHandle.set_flags(lt::torrent_flags::super_seeding);
|
m_nativeHandle.set_flags(lt::torrent_flags::super_seeding);
|
||||||
else
|
else
|
||||||
m_nativeHandle.unset_flags(lt::torrent_flags::super_seeding);
|
m_nativeHandle.unset_flags(lt::torrent_flags::super_seeding);
|
||||||
saveResumeData();
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setDHTDisabled(const bool disable)
|
void TorrentImpl::setDHTDisabled(const bool disable)
|
||||||
@ -2170,7 +2187,8 @@ void TorrentImpl::setDHTDisabled(const bool disable)
|
|||||||
m_nativeHandle.set_flags(lt::torrent_flags::disable_dht);
|
m_nativeHandle.set_flags(lt::torrent_flags::disable_dht);
|
||||||
else
|
else
|
||||||
m_nativeHandle.unset_flags(lt::torrent_flags::disable_dht);
|
m_nativeHandle.unset_flags(lt::torrent_flags::disable_dht);
|
||||||
saveResumeData();
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setPEXDisabled(const bool disable)
|
void TorrentImpl::setPEXDisabled(const bool disable)
|
||||||
@ -2182,7 +2200,8 @@ void TorrentImpl::setPEXDisabled(const bool disable)
|
|||||||
m_nativeHandle.set_flags(lt::torrent_flags::disable_pex);
|
m_nativeHandle.set_flags(lt::torrent_flags::disable_pex);
|
||||||
else
|
else
|
||||||
m_nativeHandle.unset_flags(lt::torrent_flags::disable_pex);
|
m_nativeHandle.unset_flags(lt::torrent_flags::disable_pex);
|
||||||
saveResumeData();
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::setLSDDisabled(const bool disable)
|
void TorrentImpl::setLSDDisabled(const bool disable)
|
||||||
@ -2194,7 +2213,8 @@ void TorrentImpl::setLSDDisabled(const bool disable)
|
|||||||
m_nativeHandle.set_flags(lt::torrent_flags::disable_lsd);
|
m_nativeHandle.set_flags(lt::torrent_flags::disable_lsd);
|
||||||
else
|
else
|
||||||
m_nativeHandle.unset_flags(lt::torrent_flags::disable_lsd);
|
m_nativeHandle.unset_flags(lt::torrent_flags::disable_lsd);
|
||||||
saveResumeData();
|
|
||||||
|
m_session->handleTorrentNeedSaveResumeData(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentImpl::flushCache() const
|
void TorrentImpl::flushCache() const
|
||||||
|
Loading…
x
Reference in New Issue
Block a user