mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-11 07:18:08 +00:00
Merge pull request #14993 from glassez/file-error
Provide correct error description in "upload mode"
This commit is contained in:
commit
1c34635016
@ -125,32 +125,7 @@ BitTorrent::BencodeResumeDataStorage::BencodeResumeDataStorage(const QString &pa
|
|||||||
m_registeredTorrents.append(TorrentID::fromString(rxMatch.captured(1)));
|
m_registeredTorrents.append(TorrentID::fromString(rxMatch.captured(1)));
|
||||||
}
|
}
|
||||||
|
|
||||||
QFile queueFile {m_resumeDataDir.absoluteFilePath(QLatin1String("queue"))};
|
loadQueue(m_resumeDataDir.absoluteFilePath(QLatin1String("queue")));
|
||||||
if (queueFile.open(QFile::ReadOnly))
|
|
||||||
{
|
|
||||||
const QRegularExpression hashPattern {QLatin1String("^([A-Fa-f0-9]{40})$")};
|
|
||||||
QByteArray line;
|
|
||||||
int start = 0;
|
|
||||||
while (!(line = queueFile.readLine().trimmed()).isEmpty())
|
|
||||||
{
|
|
||||||
const QRegularExpressionMatch rxMatch = hashPattern.match(line);
|
|
||||||
if (rxMatch.hasMatch())
|
|
||||||
{
|
|
||||||
const auto torrentID = TorrentID::fromString(rxMatch.captured(1));
|
|
||||||
const int pos = m_registeredTorrents.indexOf(torrentID, start);
|
|
||||||
if (pos != -1)
|
|
||||||
{
|
|
||||||
std::swap(m_registeredTorrents[start], m_registeredTorrents[pos]);
|
|
||||||
++start;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
LogMsg(tr("Couldn't load torrents queue from '%1'. Error: %2")
|
|
||||||
.arg(queueFile.fileName(), queueFile.errorString()), Log::WARNING);
|
|
||||||
}
|
|
||||||
|
|
||||||
qDebug("Registered torrents count: %d", m_registeredTorrents.size());
|
qDebug("Registered torrents count: %d", m_registeredTorrents.size());
|
||||||
|
|
||||||
@ -295,6 +270,39 @@ void BitTorrent::BencodeResumeDataStorage::storeQueue(const QVector<TorrentID> &
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BitTorrent::BencodeResumeDataStorage::loadQueue(const QString &queueFilename)
|
||||||
|
{
|
||||||
|
QFile queueFile {queueFilename};
|
||||||
|
if (!queueFile.exists())
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (queueFile.open(QFile::ReadOnly))
|
||||||
|
{
|
||||||
|
const QRegularExpression hashPattern {QLatin1String("^([A-Fa-f0-9]{40})$")};
|
||||||
|
QByteArray line;
|
||||||
|
int start = 0;
|
||||||
|
while (!(line = queueFile.readLine().trimmed()).isEmpty())
|
||||||
|
{
|
||||||
|
const QRegularExpressionMatch rxMatch = hashPattern.match(line);
|
||||||
|
if (rxMatch.hasMatch())
|
||||||
|
{
|
||||||
|
const auto torrentID = TorrentID::fromString(rxMatch.captured(1));
|
||||||
|
const int pos = m_registeredTorrents.indexOf(torrentID, start);
|
||||||
|
if (pos != -1)
|
||||||
|
{
|
||||||
|
std::swap(m_registeredTorrents[start], m_registeredTorrents[pos]);
|
||||||
|
++start;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
LogMsg(tr("Couldn't load torrents queue from '%1'. Error: %2")
|
||||||
|
.arg(queueFile.fileName(), queueFile.errorString()), Log::WARNING);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
BitTorrent::BencodeResumeDataStorage::Worker::Worker(const QDir &resumeDataDir)
|
BitTorrent::BencodeResumeDataStorage::Worker::Worker(const QDir &resumeDataDir)
|
||||||
: m_resumeDataDir {resumeDataDir}
|
: m_resumeDataDir {resumeDataDir}
|
||||||
{
|
{
|
||||||
|
@ -56,6 +56,7 @@ namespace BitTorrent
|
|||||||
void storeQueue(const QVector<TorrentID> &queue) const override;
|
void storeQueue(const QVector<TorrentID> &queue) const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void loadQueue(const QString &queueFilename);
|
||||||
std::optional<LoadTorrentParams> loadTorrentResumeData(const QByteArray &data, const TorrentInfo &metadata) const;
|
std::optional<LoadTorrentParams> loadTorrentResumeData(const QByteArray &data, const TorrentInfo &metadata) const;
|
||||||
|
|
||||||
const QDir m_resumeDataDir;
|
const QDir m_resumeDataDir;
|
||||||
|
@ -4580,8 +4580,9 @@ void Session::handleFileErrorAlert(const lt::file_error_alert *p)
|
|||||||
if (!torrent)
|
if (!torrent)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const TorrentID id = torrent->id();
|
torrent->handleAlert(p);
|
||||||
|
|
||||||
|
const TorrentID id = torrent->id();
|
||||||
if (!m_recentErroredTorrents.contains(id))
|
if (!m_recentErroredTorrents.contains(id))
|
||||||
{
|
{
|
||||||
m_recentErroredTorrents.insert(id);
|
m_recentErroredTorrents.insert(id);
|
||||||
|
@ -1005,7 +1005,13 @@ QString TorrentImpl::error() const
|
|||||||
return QString::fromStdString(m_nativeStatus.errc.message());
|
return QString::fromStdString(m_nativeStatus.errc.message());
|
||||||
|
|
||||||
if (m_nativeStatus.flags & lt::torrent_flags::upload_mode)
|
if (m_nativeStatus.flags & lt::torrent_flags::upload_mode)
|
||||||
return tr("There's not enough space on disk. Torrent is currently in \"upload only\" mode.");
|
{
|
||||||
|
const QString writeErrorStr = tr("Couldn't write to file.");
|
||||||
|
const QString uploadModeStr = tr("Torrent is currently in \"upload only\" mode.");
|
||||||
|
const QString errorMessage = QString::fromLocal8Bit(m_lastFileError.error.message().c_str());
|
||||||
|
|
||||||
|
return writeErrorStr + QLatin1Char(' ') + errorMessage + QLatin1String(". ") + uploadModeStr;
|
||||||
|
}
|
||||||
|
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@ -1922,6 +1928,11 @@ void TorrentImpl::handleFileCompletedAlert(const lt::file_completed_alert *p)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TorrentImpl::handleFileErrorAlert(const lt::file_error_alert *p)
|
||||||
|
{
|
||||||
|
m_lastFileError = {p->error, p->op};
|
||||||
|
}
|
||||||
|
|
||||||
#if (LIBTORRENT_VERSION_NUM >= 20003)
|
#if (LIBTORRENT_VERSION_NUM >= 20003)
|
||||||
void TorrentImpl::handleFilePrioAlert(const lt::file_prio_alert *)
|
void TorrentImpl::handleFilePrioAlert(const lt::file_prio_alert *)
|
||||||
{
|
{
|
||||||
@ -1981,6 +1992,9 @@ void TorrentImpl::handleAlert(const lt::alert *a)
|
|||||||
case lt::file_completed_alert::alert_type:
|
case lt::file_completed_alert::alert_type:
|
||||||
handleFileCompletedAlert(static_cast<const lt::file_completed_alert*>(a));
|
handleFileCompletedAlert(static_cast<const lt::file_completed_alert*>(a));
|
||||||
break;
|
break;
|
||||||
|
case lt::file_error_alert::alert_type:
|
||||||
|
handleFileErrorAlert(static_cast<const lt::file_error_alert*>(a));
|
||||||
|
break;
|
||||||
case lt::torrent_finished_alert::alert_type:
|
case lt::torrent_finished_alert::alert_type:
|
||||||
handleTorrentFinishedAlert(static_cast<const lt::torrent_finished_alert*>(a));
|
handleTorrentFinishedAlert(static_cast<const lt::torrent_finished_alert*>(a));
|
||||||
break;
|
break;
|
||||||
|
@ -78,6 +78,12 @@ namespace BitTorrent
|
|||||||
HandleMetadata
|
HandleMetadata
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct FileErrorInfo
|
||||||
|
{
|
||||||
|
lt::error_code error;
|
||||||
|
lt::operation_t operation;
|
||||||
|
};
|
||||||
|
|
||||||
class TorrentImpl final : public QObject, public Torrent
|
class TorrentImpl final : public QObject, public Torrent
|
||||||
{
|
{
|
||||||
Q_DISABLE_COPY(TorrentImpl)
|
Q_DISABLE_COPY(TorrentImpl)
|
||||||
@ -255,6 +261,7 @@ namespace BitTorrent
|
|||||||
|
|
||||||
void handleFastResumeRejectedAlert(const lt::fastresume_rejected_alert *p);
|
void handleFastResumeRejectedAlert(const lt::fastresume_rejected_alert *p);
|
||||||
void handleFileCompletedAlert(const lt::file_completed_alert *p);
|
void handleFileCompletedAlert(const lt::file_completed_alert *p);
|
||||||
|
void handleFileErrorAlert(const lt::file_error_alert *p);
|
||||||
#if (LIBTORRENT_VERSION_NUM >= 20003)
|
#if (LIBTORRENT_VERSION_NUM >= 20003)
|
||||||
void handleFilePrioAlert(const lt::file_prio_alert *p);
|
void handleFilePrioAlert(const lt::file_prio_alert *p);
|
||||||
#endif
|
#endif
|
||||||
@ -310,6 +317,7 @@ namespace BitTorrent
|
|||||||
QHash<lt::file_index_t, QVector<QString>> m_oldPath;
|
QHash<lt::file_index_t, QVector<QString>> m_oldPath;
|
||||||
|
|
||||||
QHash<QString, QMap<lt::tcp::endpoint, int>> m_trackerPeerCounts;
|
QHash<QString, QMap<lt::tcp::endpoint, int>> m_trackerPeerCounts;
|
||||||
|
FileErrorInfo m_lastFileError;
|
||||||
|
|
||||||
// Persistent data
|
// Persistent data
|
||||||
QString m_name;
|
QString m_name;
|
||||||
|
Loading…
Reference in New Issue
Block a user