mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 13:04:23 +00:00
Merge pull request #4175 from glassez/seq_dl
Prevent return cached "sequential download" state. Closes #4167.
This commit is contained in:
commit
0a0c8f307b
@ -189,7 +189,6 @@ TorrentHandle::TorrentHandle(Session *session, const libtorrent::torrent_handle
|
|||||||
if (!data.resumed) {
|
if (!data.resumed) {
|
||||||
setSequentialDownload(data.sequential);
|
setSequentialDownload(data.sequential);
|
||||||
if (hasMetadata()) {
|
if (hasMetadata()) {
|
||||||
setFirstLastPiecePriority(data.sequential);
|
|
||||||
if (m_session->isAppendExtensionEnabled())
|
if (m_session->isAppendExtensionEnabled())
|
||||||
appendExtensionsToIncompleteFiles();
|
appendExtensionsToIncompleteFiles();
|
||||||
}
|
}
|
||||||
@ -1088,11 +1087,6 @@ void TorrentHandle::setLabel(const QString &label)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentHandle::setSequentialDownload(bool b)
|
|
||||||
{
|
|
||||||
SAFE_CALL(set_sequential_download, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
void TorrentHandle::move(QString path)
|
void TorrentHandle::move(QString path)
|
||||||
{
|
{
|
||||||
path = Utils::Fs::toNativePath(path);
|
path = Utils::Fs::toNativePath(path);
|
||||||
@ -1130,24 +1124,23 @@ void TorrentHandle::forceRecheck()
|
|||||||
SAFE_CALL(force_recheck);
|
SAFE_CALL(force_recheck);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentHandle::toggleSequentialDownload()
|
void TorrentHandle::setSequentialDownload(bool b)
|
||||||
{
|
{
|
||||||
if (hasMetadata()) {
|
if (b != isSequentialDownload()) {
|
||||||
bool was_sequential = isSequentialDownload();
|
SAFE_CALL(set_sequential_download, b);
|
||||||
SAFE_CALL(set_sequential_download, !was_sequential);
|
m_nativeStatus.sequential_download = b; // prevent return cached value
|
||||||
if (!was_sequential)
|
|
||||||
setFirstLastPiecePriority(true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentHandle::toggleFirstLastPiecePriority()
|
void TorrentHandle::toggleSequentialDownload()
|
||||||
{
|
{
|
||||||
if (hasMetadata())
|
setSequentialDownload(!isSequentialDownload());
|
||||||
setFirstLastPiecePriority(!hasFirstLastPiecePriority());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TorrentHandle::setFirstLastPiecePriority(bool b)
|
void TorrentHandle::setFirstLastPiecePriority(bool b)
|
||||||
{
|
{
|
||||||
|
if (!hasMetadata()) return;
|
||||||
|
|
||||||
std::vector<int> fp;
|
std::vector<int> fp;
|
||||||
SAFE_GET(fp, file_priorities);
|
SAFE_GET(fp, file_priorities);
|
||||||
|
|
||||||
@ -1168,6 +1161,11 @@ void TorrentHandle::setFirstLastPiecePriority(bool b)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TorrentHandle::toggleFirstLastPiecePriority()
|
||||||
|
{
|
||||||
|
setFirstLastPiecePriority(!hasFirstLastPiecePriority());
|
||||||
|
}
|
||||||
|
|
||||||
void TorrentHandle::pause()
|
void TorrentHandle::pause()
|
||||||
{
|
{
|
||||||
if (isPaused()) return;
|
if (isPaused()) return;
|
||||||
@ -1756,9 +1754,12 @@ QString TorrentHandle::toMagnetUri() const
|
|||||||
|
|
||||||
void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
|
void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
|
||||||
{
|
{
|
||||||
qDebug() << Q_FUNC_INFO;
|
if (!hasMetadata()) return;
|
||||||
if (priorities.size() != filesCount()) return;
|
if (priorities.size() != filesCount()) return;
|
||||||
|
|
||||||
|
// Save first/last piece first option state
|
||||||
|
bool firstLastPieceFirst = hasFirstLastPiecePriority();
|
||||||
|
|
||||||
// Reset 'm_hasSeedStatus' if needed in order to react again to
|
// Reset 'm_hasSeedStatus' if needed in order to react again to
|
||||||
// 'torrent_finished_alert' and eg show tray notifications
|
// 'torrent_finished_alert' and eg show tray notifications
|
||||||
QVector<qreal> progress = filesProgress();
|
QVector<qreal> progress = filesProgress();
|
||||||
@ -1828,5 +1829,9 @@ void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Restore first/last piece first option if necessary
|
||||||
|
if (firstLastPieceFirst)
|
||||||
|
setFirstLastPiecePriority(true);
|
||||||
|
|
||||||
updateStatus();
|
updateStatus();
|
||||||
}
|
}
|
||||||
|
@ -304,8 +304,8 @@ namespace BitTorrent
|
|||||||
void setLabel(const QString &label);
|
void setLabel(const QString &label);
|
||||||
void setSequentialDownload(bool b);
|
void setSequentialDownload(bool b);
|
||||||
void toggleSequentialDownload();
|
void toggleSequentialDownload();
|
||||||
void toggleFirstLastPiecePriority();
|
|
||||||
void setFirstLastPiecePriority(bool b);
|
void setFirstLastPiecePriority(bool b);
|
||||||
|
void toggleFirstLastPiecePriority();
|
||||||
void pause();
|
void pause();
|
||||||
void resume(bool forced = false);
|
void resume(bool forced = false);
|
||||||
void move(QString path);
|
void move(QString path);
|
||||||
|
@ -450,7 +450,7 @@ void PropertiesWidget::loadDynamicData() {
|
|||||||
downloaded_pieces->setProgress(m_torrent->pieces(), m_torrent->downloadingPieces());
|
downloaded_pieces->setProgress(m_torrent->pieces(), m_torrent->downloadingPieces());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
showPiecesAvailability(false);
|
showPiecesAvailability(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -840,14 +840,9 @@ void PropertiesWidget::editWebSeed() {
|
|||||||
bool PropertiesWidget::applyPriorities() {
|
bool PropertiesWidget::applyPriorities() {
|
||||||
qDebug("Saving files priorities");
|
qDebug("Saving files priorities");
|
||||||
const QVector<int> priorities = PropListModel->model()->getFilePriorities();
|
const QVector<int> priorities = PropListModel->model()->getFilePriorities();
|
||||||
// Save first/last piece first option state
|
|
||||||
bool first_last_piece_first = m_torrent->hasFirstLastPiecePriority();
|
|
||||||
// Prioritize the files
|
// Prioritize the files
|
||||||
qDebug("prioritize files: %d", priorities[0]);
|
qDebug("prioritize files: %d", priorities[0]);
|
||||||
m_torrent->prioritizeFiles(priorities);
|
m_torrent->prioritizeFiles(priorities);
|
||||||
// Restore first/last piece first option if necessary
|
|
||||||
if (first_last_piece_first)
|
|
||||||
m_torrent->setFirstLastPiecePriority(true);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -562,7 +562,7 @@ void TransferListWidget::toggleSelectedTorrentsSequentialDownload() const
|
|||||||
void TransferListWidget::toggleSelectedFirstLastPiecePrio() const
|
void TransferListWidget::toggleSelectedFirstLastPiecePrio() const
|
||||||
{
|
{
|
||||||
foreach (BitTorrent::TorrentHandle *const torrent, getSelectedTorrents())
|
foreach (BitTorrent::TorrentHandle *const torrent, getSelectedTorrents())
|
||||||
torrent->setFirstLastPiecePriority(!torrent->hasFirstLastPiecePriority());
|
torrent->toggleFirstLastPiecePriority();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransferListWidget::askNewLabelForSelection()
|
void TransferListWidget::askNewLabelForSelection()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user