|
|
@ -163,6 +163,7 @@ QBtSession::QBtSession() |
|
|
|
downloader = new DownloadThread(this); |
|
|
|
downloader = new DownloadThread(this); |
|
|
|
connect(downloader, SIGNAL(downloadFinished(QString, QString)), SLOT(processDownloadedFile(QString, QString))); |
|
|
|
connect(downloader, SIGNAL(downloadFinished(QString, QString)), SLOT(processDownloadedFile(QString, QString))); |
|
|
|
connect(downloader, SIGNAL(downloadFailure(QString, QString)), SLOT(handleDownloadFailure(QString, QString))); |
|
|
|
connect(downloader, SIGNAL(downloadFailure(QString, QString)), SLOT(handleDownloadFailure(QString, QString))); |
|
|
|
|
|
|
|
connect(downloader, SIGNAL(magnetRedirect(QString, QString)), SLOT(handleMagnetRedirect(QString, QString))); |
|
|
|
// Regular saving of fastresume data
|
|
|
|
// Regular saving of fastresume data
|
|
|
|
connect(&resumeDataTimer, SIGNAL(timeout()), SLOT(saveTempFastResumeData())); |
|
|
|
connect(&resumeDataTimer, SIGNAL(timeout()), SLOT(saveTempFastResumeData())); |
|
|
|
resumeDataTimer.start(170000); // 3min
|
|
|
|
resumeDataTimer.start(170000); // 3min
|
|
|
@ -272,6 +273,20 @@ void QBtSession::handleDownloadFailure(QString url, QString reason) { |
|
|
|
savepathLabel_fromurl.remove(qurl); |
|
|
|
savepathLabel_fromurl.remove(qurl); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void QBtSession::handleMagnetRedirect(const QString &url_new, const QString &url_old) { |
|
|
|
|
|
|
|
if (url_skippingDlg.contains(url_old)) { |
|
|
|
|
|
|
|
url_skippingDlg.removeOne(url_old); |
|
|
|
|
|
|
|
QPair<QString, QString> savePath_label; |
|
|
|
|
|
|
|
if (savepathLabel_fromurl.contains(url_old)) { |
|
|
|
|
|
|
|
savePath_label = savepathLabel_fromurl.take(QUrl::fromEncoded(url_old.toUtf8())); |
|
|
|
|
|
|
|
savepathLabel_fromurl.remove(url_old); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
addMagnetSkipAddDlg(url_new, savePath_label.first, savePath_label.second, url_old); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
addMagnetInteractive(url_new); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void QBtSession::setQueueingEnabled(bool enable) { |
|
|
|
void QBtSession::setQueueingEnabled(bool enable) { |
|
|
|
if (queueingEnabled != enable) { |
|
|
|
if (queueingEnabled != enable) { |
|
|
|
qDebug("Queueing system is changing state..."); |
|
|
|
qDebug("Queueing system is changing state..."); |
|
|
@ -2843,11 +2858,11 @@ void QBtSession::addMagnetInteractive(const QString& uri) |
|
|
|
emit newMagnetLink(uri); |
|
|
|
emit newMagnetLink(uri); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void QBtSession::addMagnetSkipAddDlg(const QString& uri, const QString& save_path, const QString& label) { |
|
|
|
void QBtSession::addMagnetSkipAddDlg(const QString& uri, const QString& save_path, const QString& label, const QString &uri_old) { |
|
|
|
if (!save_path.isEmpty() || !label.isEmpty()) |
|
|
|
if (!save_path.isEmpty() || !label.isEmpty()) |
|
|
|
savepathLabel_fromurl[uri] = qMakePair(fsutils::fromNativePath(save_path), label); |
|
|
|
savepathLabel_fromurl[uri] = qMakePair(fsutils::fromNativePath(save_path), label); |
|
|
|
addMagnetUri(uri, false); |
|
|
|
addMagnetUri(uri, false); |
|
|
|
emit newDownloadedTorrentFromRss(uri); |
|
|
|
emit newDownloadedTorrentFromRss(uri_old.isEmpty() ? uri : uri_old); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void QBtSession::downloadUrlAndSkipDialog(QString url, QString save_path, QString label, const QList<QNetworkCookie>& cookies) { |
|
|
|
void QBtSession::downloadUrlAndSkipDialog(QString url, QString save_path, QString label, const QList<QNetworkCookie>& cookies) { |
|
|
|