mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-11 23:37:59 +00:00
Merge pull request #11126 from Chocobo1/addedTime
Fix wrong "added on" date
This commit is contained in:
commit
7ce26435bd
@ -156,31 +156,6 @@ namespace
|
|||||||
return QString::fromUtf8(str.data(), static_cast<int>(str.size()));
|
return QString::fromUtf8(str.data(), static_cast<int>(str.size()));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Entry>
|
|
||||||
QSet<QString> entryListToSetImpl(const Entry &entry)
|
|
||||||
{
|
|
||||||
Q_ASSERT(entry.type() == Entry::list_t);
|
|
||||||
QSet<QString> output;
|
|
||||||
for (int i = 0; i < entry.list_size(); ++i) {
|
|
||||||
const QString tag = fromLTString(entry.list_string_value_at(i));
|
|
||||||
if (Session::isValidTag(tag))
|
|
||||||
output.insert(tag);
|
|
||||||
else
|
|
||||||
qWarning() << QString("Dropping invalid stored tag: %1").arg(tag);
|
|
||||||
}
|
|
||||||
return output;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isList(const lt::bdecode_node &entry)
|
|
||||||
{
|
|
||||||
return entry.type() == lt::bdecode_node::list_t;
|
|
||||||
}
|
|
||||||
|
|
||||||
QSet<QString> entryListToSet(const lt::bdecode_node &entry)
|
|
||||||
{
|
|
||||||
return entryListToSetImpl(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
QString normalizePath(const QString &path)
|
QString normalizePath(const QString &path)
|
||||||
{
|
{
|
||||||
QString tmp = Utils::Fs::toUniformPath(path.trimmed());
|
QString tmp = Utils::Fs::toUniformPath(path.trimmed());
|
||||||
@ -2028,6 +2003,11 @@ bool Session::addTorrent_impl(CreateTorrentParams params, const MagnetUri &magne
|
|||||||
p.upload_limit = params.uploadLimit;
|
p.upload_limit = params.uploadLimit;
|
||||||
p.download_limit = params.downloadLimit;
|
p.download_limit = params.downloadLimit;
|
||||||
|
|
||||||
|
#if (LIBTORRENT_VERSION_NUM >= 10200)
|
||||||
|
if (params.addedTime.isValid())
|
||||||
|
p.added_time = params.addedTime.toSecsSinceEpoch();
|
||||||
|
#endif
|
||||||
|
|
||||||
// Preallocation mode
|
// Preallocation mode
|
||||||
p.storage_mode = isPreallocationEnabled()
|
p.storage_mode = isPreallocationEnabled()
|
||||||
? lt::storage_mode_allocate : lt::storage_mode_sparse;
|
? lt::storage_mode_allocate : lt::storage_mode_sparse;
|
||||||
@ -3662,13 +3642,13 @@ void Session::startUpTorrents()
|
|||||||
QStringList fastresumes = resumeDataDir.entryList(
|
QStringList fastresumes = resumeDataDir.entryList(
|
||||||
QStringList(QLatin1String("*.fastresume")), QDir::Files, QDir::Unsorted);
|
QStringList(QLatin1String("*.fastresume")), QDir::Files, QDir::Unsorted);
|
||||||
|
|
||||||
typedef struct
|
struct TorrentResumeData
|
||||||
{
|
{
|
||||||
QString hash;
|
QString hash;
|
||||||
MagnetUri magnetUri;
|
MagnetUri magnetUri;
|
||||||
CreateTorrentParams addTorrentData;
|
CreateTorrentParams addTorrentData;
|
||||||
QByteArray data;
|
QByteArray data;
|
||||||
} TorrentResumeData;
|
};
|
||||||
|
|
||||||
int resumedTorrentsCount = 0;
|
int resumedTorrentsCount = 0;
|
||||||
const auto startupTorrent = [this, &resumeDataDir, &resumedTorrentsCount](const TorrentResumeData ¶ms)
|
const auto startupTorrent = [this, &resumeDataDir, &resumedTorrentsCount](const TorrentResumeData ¶ms)
|
||||||
@ -4422,49 +4402,59 @@ namespace
|
|||||||
|
|
||||||
bool loadTorrentResumeData(const QByteArray &data, CreateTorrentParams &torrentParams, int &queuePos, MagnetUri &magnetUri)
|
bool loadTorrentResumeData(const QByteArray &data, CreateTorrentParams &torrentParams, int &queuePos, MagnetUri &magnetUri)
|
||||||
{
|
{
|
||||||
|
lt::error_code ec;
|
||||||
|
lt::bdecode_node root;
|
||||||
|
lt::bdecode(data.constData(), (data.constData() + data.size()), root, ec);
|
||||||
|
if (ec || (root.type() != lt::bdecode_node::dict_t)) return false;
|
||||||
|
|
||||||
torrentParams = CreateTorrentParams();
|
torrentParams = CreateTorrentParams();
|
||||||
|
|
||||||
torrentParams.restored = true;
|
torrentParams.restored = true;
|
||||||
torrentParams.skipChecking = false;
|
torrentParams.skipChecking = false;
|
||||||
|
torrentParams.name = fromLTString(root.dict_find_string_value("qBt-name"));
|
||||||
lt::error_code ec;
|
|
||||||
lt::bdecode_node fast;
|
|
||||||
lt::bdecode(data.constData(), data.constData() + data.size(), fast, ec);
|
|
||||||
if (ec || (fast.type() != lt::bdecode_node::dict_t)) return false;
|
|
||||||
|
|
||||||
torrentParams.savePath = Profile::instance().fromPortablePath(
|
torrentParams.savePath = Profile::instance().fromPortablePath(
|
||||||
Utils::Fs::toUniformPath(fromLTString(fast.dict_find_string_value("qBt-savePath"))));
|
Utils::Fs::toUniformPath(fromLTString(root.dict_find_string_value("qBt-savePath"))));
|
||||||
|
torrentParams.disableTempPath = root.dict_find_int_value("qBt-tempPathDisabled");
|
||||||
|
torrentParams.sequential = root.dict_find_int_value("qBt-sequential");
|
||||||
|
torrentParams.hasSeedStatus = root.dict_find_int_value("qBt-seedStatus");
|
||||||
|
torrentParams.firstLastPiecePriority = root.dict_find_int_value("qBt-firstLastPiecePriority");
|
||||||
|
torrentParams.hasRootFolder = root.dict_find_int_value("qBt-hasRootFolder");
|
||||||
|
torrentParams.seedingTimeLimit = root.dict_find_int_value("qBt-seedingTimeLimit", TorrentHandle::USE_GLOBAL_SEEDING_TIME);
|
||||||
|
|
||||||
LTString ratioLimitString = fast.dict_find_string_value("qBt-ratioLimit");
|
const bool isAutoManaged = root.dict_find_int_value("auto_managed");
|
||||||
|
const bool isPaused = root.dict_find_int_value("paused");
|
||||||
|
torrentParams.paused = root.dict_find_int_value("qBt-paused", (isPaused && !isAutoManaged));
|
||||||
|
torrentParams.forced = root.dict_find_int_value("qBt-forced", (!isPaused && !isAutoManaged));
|
||||||
|
|
||||||
|
const LTString ratioLimitString = root.dict_find_string_value("qBt-ratioLimit");
|
||||||
if (ratioLimitString.empty())
|
if (ratioLimitString.empty())
|
||||||
torrentParams.ratioLimit = fast.dict_find_int_value("qBt-ratioLimit", TorrentHandle::USE_GLOBAL_RATIO * 1000) / 1000.0;
|
torrentParams.ratioLimit = root.dict_find_int_value("qBt-ratioLimit", TorrentHandle::USE_GLOBAL_RATIO * 1000) / 1000.0;
|
||||||
else
|
else
|
||||||
torrentParams.ratioLimit = fromLTString(ratioLimitString).toDouble();
|
torrentParams.ratioLimit = fromLTString(ratioLimitString).toDouble();
|
||||||
torrentParams.seedingTimeLimit = fast.dict_find_int_value("qBt-seedingTimeLimit", TorrentHandle::USE_GLOBAL_SEEDING_TIME);
|
|
||||||
// **************************************************************************************
|
// **************************************************************************************
|
||||||
// Workaround to convert legacy label to category
|
// Workaround to convert legacy label to category
|
||||||
// TODO: Should be removed in future
|
// TODO: Should be removed in future
|
||||||
torrentParams.category = fromLTString(fast.dict_find_string_value("qBt-label"));
|
torrentParams.category = fromLTString(root.dict_find_string_value("qBt-label"));
|
||||||
if (torrentParams.category.isEmpty())
|
if (torrentParams.category.isEmpty())
|
||||||
// **************************************************************************************
|
// **************************************************************************************
|
||||||
torrentParams.category = fromLTString(fast.dict_find_string_value("qBt-category"));
|
torrentParams.category = fromLTString(root.dict_find_string_value("qBt-category"));
|
||||||
// auto because the return type depends on the #if above.
|
|
||||||
const auto tagsEntry = fast.dict_find_list("qBt-tags");
|
|
||||||
if (isList(tagsEntry))
|
|
||||||
torrentParams.tags = entryListToSet(tagsEntry);
|
|
||||||
torrentParams.name = fromLTString(fast.dict_find_string_value("qBt-name"));
|
|
||||||
torrentParams.hasSeedStatus = fast.dict_find_int_value("qBt-seedStatus");
|
|
||||||
torrentParams.disableTempPath = fast.dict_find_int_value("qBt-tempPathDisabled");
|
|
||||||
torrentParams.hasRootFolder = fast.dict_find_int_value("qBt-hasRootFolder");
|
|
||||||
|
|
||||||
magnetUri = MagnetUri(fromLTString(fast.dict_find_string_value("qBt-magnetUri")));
|
const lt::bdecode_node tagsNode = root.dict_find("qBt-tags");
|
||||||
const bool isAutoManaged = fast.dict_find_int_value("auto_managed");
|
if (tagsNode.type() == lt::bdecode_node::list_t) {
|
||||||
const bool isPaused = fast.dict_find_int_value("paused");
|
for (int i = 0; i < tagsNode.list_size(); ++i) {
|
||||||
torrentParams.paused = fast.dict_find_int_value("qBt-paused", (isPaused && !isAutoManaged));
|
const QString tag = fromLTString(tagsNode.list_string_value_at(i));
|
||||||
torrentParams.forced = fast.dict_find_int_value("qBt-forced", (!isPaused && !isAutoManaged));
|
if (Session::isValidTag(tag))
|
||||||
torrentParams.firstLastPiecePriority = fast.dict_find_int_value("qBt-firstLastPiecePriority");
|
torrentParams.tags << tag;
|
||||||
torrentParams.sequential = fast.dict_find_int_value("qBt-sequential");
|
}
|
||||||
|
}
|
||||||
|
|
||||||
queuePos = fast.dict_find_int_value("qBt-queuePosition");
|
const lt::bdecode_node addedTimeNode = root.dict_find("qBt-addedTime");
|
||||||
|
if (addedTimeNode.type() == lt::bdecode_node::int_t)
|
||||||
|
torrentParams.addedTime = QDateTime::fromSecsSinceEpoch(addedTimeNode.int_value());
|
||||||
|
|
||||||
|
queuePos = root.dict_find_int_value("qBt-queuePosition");
|
||||||
|
magnetUri = MagnetUri(fromLTString(root.dict_find_string_value("qBt-magnetUri")));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <QBitArray>
|
#include <QBitArray>
|
||||||
#include <QDateTime>
|
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
@ -1775,6 +1774,8 @@ void TorrentHandle::handleSaveResumeDataAlert(const lt::save_resume_data_alert *
|
|||||||
// restored if qBittorrent quits before the metadata are retrieved:
|
// restored if qBittorrent quits before the metadata are retrieved:
|
||||||
resumeData["qBt-firstLastPiecePriority"] = hasFirstLastPiecePriority();
|
resumeData["qBt-firstLastPiecePriority"] = hasFirstLastPiecePriority();
|
||||||
resumeData["qBt-sequential"] = isSequentialDownload();
|
resumeData["qBt-sequential"] = isSequentialDownload();
|
||||||
|
|
||||||
|
resumeData["qBt-addedTime"] = addedTime().toSecsSinceEpoch();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const auto savePath = resumeData.find_key("save_path")->string();
|
const auto savePath = resumeData.find_key("save_path")->string();
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include <libtorrent/torrent_handle.hpp>
|
#include <libtorrent/torrent_handle.hpp>
|
||||||
#include <libtorrent/torrent_status.hpp>
|
#include <libtorrent/torrent_status.hpp>
|
||||||
|
|
||||||
|
#include <QDateTime>
|
||||||
#include <QHash>
|
#include <QHash>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QQueue>
|
#include <QQueue>
|
||||||
@ -83,6 +84,7 @@ namespace BitTorrent
|
|||||||
int downloadLimit;
|
int downloadLimit;
|
||||||
// for new torrents
|
// for new torrents
|
||||||
QVector<DownloadPriority> filePriorities;
|
QVector<DownloadPriority> filePriorities;
|
||||||
|
QDateTime addedTime;
|
||||||
// for restored torrents
|
// for restored torrents
|
||||||
qreal ratioLimit;
|
qreal ratioLimit;
|
||||||
int seedingTimeLimit;
|
int seedingTimeLimit;
|
||||||
|
Loading…
Reference in New Issue
Block a user