Browse Source

- Do not save fastresume data regularly for seeding torrents

adaptive-webui-19844
Christophe Dumez 17 years ago
parent
commit
7982011d0b
  1. 40
      src/bittorrent.cpp
  2. 2
      src/bittorrent.h

40
src/bittorrent.cpp

@ -59,7 +59,7 @@ bittorrent::bittorrent() : timerScan(0), DHTEnabled(false), preAllocateAll(false @@ -59,7 +59,7 @@ bittorrent::bittorrent() : timerScan(0), DHTEnabled(false), preAllocateAll(false
connect(ETARefresher, SIGNAL(timeout()), this, SLOT(updateETAs()));
ETARefresher->start(ETA_REFRESH_INTERVAL);
fastResumeSaver = new QTimer();
connect(fastResumeSaver, SIGNAL(timeout()), this, SLOT(saveFastResumeAndRatioData()));
connect(fastResumeSaver, SIGNAL(timeout()), this, SLOT(saveFastResumeAndRatioDataUnfinished()));
fastResumeSaver->start(60000);
// To download from urls
downloader = new downloadThread(this);
@ -310,6 +310,8 @@ void bittorrent::setFinishedTorrent(QString hash) { @@ -310,6 +310,8 @@ void bittorrent::setFinishedTorrent(QString hash) {
// Remove it from ETAs hash tables
ETAstats.remove(hash);
ETAs.remove(hash);
// Save fast resume data
saveFastResumeAndRatioData(hash);
}
// Pause a running torrent
@ -831,16 +833,18 @@ void bittorrent::saveDownloadUploadForTorrent(QString hash) { @@ -831,16 +833,18 @@ void bittorrent::saveDownloadUploadForTorrent(QString hash) {
ratio_file.close();
}
// Only save fast resume data for unfinished torrents (Optimization)
void bittorrent::saveFastResumeAndRatioDataUnfinished() {
QString hash;
QStringList hashes = getUnfinishedTorrents();
foreach(hash, hashes) {
saveFastResumeAndRatioData(hash);
}
}
// Save fastresume data for all torrents (called periodically)
void bittorrent::saveFastResumeAndRatioData() {
qDebug("Saving fast resume and ratio data");
QString file;
QDir torrentBackup(misc::qBittorrentPath() + "BT_backup");
// Checking if torrentBackup Dir exists
// create it if it is not
if(! torrentBackup.exists()) {
torrentBackup.mkpath(torrentBackup.path());
}
std::vector<torrent_handle> handles = s->get_torrents();
// It is not necessary to pause the torrents before saving fastresume data anymore
// because we either use Full allocation or sparse mode.
@ -852,7 +856,25 @@ void bittorrent::saveFastResumeAndRatioData() { @@ -852,7 +856,25 @@ void bittorrent::saveFastResumeAndRatioData() {
continue;
}
QString hash = h.hash();
saveFastResumeAndRatioData(hash);
}
qDebug("Fast resume and ratio data saved");
}
void bittorrent::saveFastResumeAndRatioData(QString hash) {
QString file;
QDir torrentBackup(misc::qBittorrentPath() + "BT_backup");
// Checking if torrentBackup Dir exists
// create it if it is not
if(! torrentBackup.exists()) {
torrentBackup.mkpath(torrentBackup.path());
}
// Extracting resume data
QTorrentHandle h = getTorrentHandle(hash);
if(!h.is_valid()) {
qDebug("/!\\ Error: Invalid handle");
return;
}
if (h.has_metadata() && h.state() != torrent_status::checking_files && h.state() != torrent_status::queued_for_checking) {
if(QFile::exists(torrentBackup.path()+QDir::separator()+hash+".torrent")) {
// Remove old .fastresume data in case it exists
@ -868,8 +890,6 @@ void bittorrent::saveFastResumeAndRatioData() { @@ -868,8 +890,6 @@ void bittorrent::saveFastResumeAndRatioData() {
saveDownloadUploadForTorrent(hash);
}
}
qDebug("Fast resume and ratio data saved");
}
bool bittorrent::isFilePreviewPossible(QString hash) const{
// See if there are supported files in the torrent

2
src/bittorrent.h

@ -98,6 +98,8 @@ class bittorrent : public QObject{ @@ -98,6 +98,8 @@ class bittorrent : public QObject{
void saveDHTEntry();
void preAllocateAllFiles(bool b);
void saveFastResumeAndRatioData();
void saveFastResumeAndRatioData(QString hash);
void saveFastResumeAndRatioDataUnfinished();
void enableDirectoryScanning(QString scan_dir);
void disableDirectoryScanning();
void enablePeerExchange();

Loading…
Cancel
Save