|
|
|
@ -555,7 +555,7 @@ void Session::configure()
@@ -555,7 +555,7 @@ void Session::configure()
|
|
|
|
|
if (pref->isSchedulerEnabled()) { |
|
|
|
|
if (!m_bwScheduler) { |
|
|
|
|
m_bwScheduler = new BandwidthScheduler(this); |
|
|
|
|
connect(m_bwScheduler, SIGNAL(switchToAlternativeMode(bool)), this, SLOT(changeSpeedLimitMode(bool))); |
|
|
|
|
connect(m_bwScheduler.data(), SIGNAL(switchToAlternativeMode(bool)), this, SLOT(switchToAlternativeMode(bool))); |
|
|
|
|
} |
|
|
|
|
m_bwScheduler->start(); |
|
|
|
|
} |
|
|
|
@ -747,6 +747,11 @@ void Session::handleRedirectedToMagnet(const QString &url, const QString &magnet
@@ -747,6 +747,11 @@ void Session::handleRedirectedToMagnet(const QString &url, const QString &magnet
|
|
|
|
|
addTorrent_impl(m_downloadedTorrents.take(url), MagnetUri(magnetUri)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void Session::switchToAlternativeMode(bool alternative) |
|
|
|
|
{ |
|
|
|
|
changeSpeedLimitMode_impl(alternative); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Add to BitTorrent session the downloaded torrent file
|
|
|
|
|
void Session::handleDownloadFinished(const QString &url, const QString &filePath) |
|
|
|
|
{ |
|
|
|
@ -757,32 +762,14 @@ void Session::handleDownloadFinished(const QString &url, const QString &filePath
@@ -757,32 +762,14 @@ void Session::handleDownloadFinished(const QString &url, const QString &filePath
|
|
|
|
|
|
|
|
|
|
void Session::changeSpeedLimitMode(bool alternative) |
|
|
|
|
{ |
|
|
|
|
qDebug() << Q_FUNC_INFO << alternative; |
|
|
|
|
// Save new state to remember it on startup
|
|
|
|
|
Preferences* const pref = Preferences::instance(); |
|
|
|
|
// Stop the scheduler when the user has manually changed the bandwidth mode
|
|
|
|
|
if (!pref->isSchedulerEnabled()) |
|
|
|
|
if (pref->isSchedulerEnabled()) { |
|
|
|
|
pref->setSchedulerEnabled(false); |
|
|
|
|
delete m_bwScheduler; |
|
|
|
|
pref->setAltBandwidthEnabled(alternative); |
|
|
|
|
|
|
|
|
|
// Apply settings to the bittorrent session
|
|
|
|
|
int downLimit = alternative ? pref->getAltGlobalDownloadLimit() : pref->getGlobalDownloadLimit(); |
|
|
|
|
if (downLimit <= 0) |
|
|
|
|
downLimit = -1; |
|
|
|
|
else |
|
|
|
|
downLimit *= 1024; |
|
|
|
|
setDownloadRateLimit(downLimit); |
|
|
|
|
|
|
|
|
|
// Upload rate
|
|
|
|
|
int upLimit = alternative ? pref->getAltGlobalUploadLimit() : pref->getGlobalUploadLimit(); |
|
|
|
|
if (upLimit <= 0) |
|
|
|
|
upLimit = -1; |
|
|
|
|
else |
|
|
|
|
upLimit *= 1024; |
|
|
|
|
setUploadRateLimit(upLimit); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Notify
|
|
|
|
|
emit speedLimitModeChanged(alternative); |
|
|
|
|
changeSpeedLimitMode_impl(alternative); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Return the torrent handle, given its hash
|
|
|
|
@ -1346,6 +1333,34 @@ void Session::enableDHT(bool enable)
@@ -1346,6 +1333,34 @@ void Session::enableDHT(bool enable)
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void Session::changeSpeedLimitMode_impl(bool alternative) |
|
|
|
|
{ |
|
|
|
|
qDebug() << Q_FUNC_INFO << alternative; |
|
|
|
|
Preferences* const pref = Preferences::instance(); |
|
|
|
|
|
|
|
|
|
// Save new state to remember it on startup
|
|
|
|
|
pref->setAltBandwidthEnabled(alternative); |
|
|
|
|
|
|
|
|
|
// Apply settings to the bittorrent session
|
|
|
|
|
int downLimit = alternative ? pref->getAltGlobalDownloadLimit() : pref->getGlobalDownloadLimit(); |
|
|
|
|
if (downLimit <= 0) |
|
|
|
|
downLimit = -1; |
|
|
|
|
else |
|
|
|
|
downLimit *= 1024; |
|
|
|
|
setDownloadRateLimit(downLimit); |
|
|
|
|
|
|
|
|
|
// Upload rate
|
|
|
|
|
int upLimit = alternative ? pref->getAltGlobalUploadLimit() : pref->getGlobalUploadLimit(); |
|
|
|
|
if (upLimit <= 0) |
|
|
|
|
upLimit = -1; |
|
|
|
|
else |
|
|
|
|
upLimit *= 1024; |
|
|
|
|
setUploadRateLimit(upLimit); |
|
|
|
|
|
|
|
|
|
// Notify
|
|
|
|
|
emit speedLimitModeChanged(alternative); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void Session::generateResumeData(bool final) |
|
|
|
|
{ |
|
|
|
|
foreach (TorrentHandle *const torrent, m_torrents) { |
|
|
|
|