1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-23 13:04:23 +00:00

Merge pull request #10220 from thalieht/const

Add const to many vars and arguments
This commit is contained in:
Mike Tzou 2019-02-13 12:11:00 +08:00 committed by GitHub
commit 78ab0e4ba9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
34 changed files with 299 additions and 301 deletions

View File

@ -127,7 +127,7 @@ Application::Application(const QString &id, int &argc, char **argv)
setApplicationName("qBittorrent"); setApplicationName("qBittorrent");
validateCommandLineParameters(); validateCommandLineParameters();
QString profileDir = m_commandLineArgs.portableMode const QString profileDir = m_commandLineArgs.portableMode
? QDir(QCoreApplication::applicationDirPath()).absoluteFilePath(DEFAULT_PORTABLE_MODE_PROFILE_DIR) ? QDir(QCoreApplication::applicationDirPath()).absoluteFilePath(DEFAULT_PORTABLE_MODE_PROFILE_DIR)
: m_commandLineArgs.profileDir; : m_commandLineArgs.profileDir;
@ -185,7 +185,7 @@ bool Application::isFileLoggerEnabled() const
return settings()->loadValue(KEY_FILELOGGER_ENABLED, true).toBool(); return settings()->loadValue(KEY_FILELOGGER_ENABLED, true).toBool();
} }
void Application::setFileLoggerEnabled(bool value) void Application::setFileLoggerEnabled(const bool value)
{ {
if (value && !m_fileLogger) if (value && !m_fileLogger)
m_fileLogger = new FileLogger(fileLoggerPath(), isFileLoggerBackup(), fileLoggerMaxSize(), isFileLoggerDeleteOld(), fileLoggerAge(), static_cast<FileLogger::FileLogAgeType>(fileLoggerAgeType())); m_fileLogger = new FileLogger(fileLoggerPath(), isFileLoggerBackup(), fileLoggerMaxSize(), isFileLoggerDeleteOld(), fileLoggerAge(), static_cast<FileLogger::FileLogAgeType>(fileLoggerAgeType()));
@ -212,7 +212,7 @@ bool Application::isFileLoggerBackup() const
return settings()->loadValue(KEY_FILELOGGER_BACKUP, true).toBool(); return settings()->loadValue(KEY_FILELOGGER_BACKUP, true).toBool();
} }
void Application::setFileLoggerBackup(bool value) void Application::setFileLoggerBackup(const bool value)
{ {
if (m_fileLogger) if (m_fileLogger)
m_fileLogger->setBackup(value); m_fileLogger->setBackup(value);
@ -224,7 +224,7 @@ bool Application::isFileLoggerDeleteOld() const
return settings()->loadValue(KEY_FILELOGGER_DELETEOLD, true).toBool(); return settings()->loadValue(KEY_FILELOGGER_DELETEOLD, true).toBool();
} }
void Application::setFileLoggerDeleteOld(bool value) void Application::setFileLoggerDeleteOld(const bool value)
{ {
if (value && m_fileLogger) if (value && m_fileLogger)
m_fileLogger->deleteOld(fileLoggerAge(), static_cast<FileLogger::FileLogAgeType>(fileLoggerAgeType())); m_fileLogger->deleteOld(fileLoggerAge(), static_cast<FileLogger::FileLogAgeType>(fileLoggerAgeType()));
@ -233,13 +233,13 @@ void Application::setFileLoggerDeleteOld(bool value)
int Application::fileLoggerMaxSize() const int Application::fileLoggerMaxSize() const
{ {
int val = settings()->loadValue(KEY_FILELOGGER_MAXSIZEBYTES, DEFAULT_FILELOG_SIZE).toInt(); const int val = settings()->loadValue(KEY_FILELOGGER_MAXSIZEBYTES, DEFAULT_FILELOG_SIZE).toInt();
return std::min(std::max(val, MIN_FILELOG_SIZE), MAX_FILELOG_SIZE); return std::min(std::max(val, MIN_FILELOG_SIZE), MAX_FILELOG_SIZE);
} }
void Application::setFileLoggerMaxSize(const int bytes) void Application::setFileLoggerMaxSize(const int bytes)
{ {
int clampedValue = std::min(std::max(bytes, MIN_FILELOG_SIZE), MAX_FILELOG_SIZE); const int clampedValue = std::min(std::max(bytes, MIN_FILELOG_SIZE), MAX_FILELOG_SIZE);
if (m_fileLogger) if (m_fileLogger)
m_fileLogger->setMaxSize(clampedValue); m_fileLogger->setMaxSize(clampedValue);
settings()->storeValue(KEY_FILELOGGER_MAXSIZEBYTES, clampedValue); settings()->storeValue(KEY_FILELOGGER_MAXSIZEBYTES, clampedValue);
@ -247,7 +247,7 @@ void Application::setFileLoggerMaxSize(const int bytes)
int Application::fileLoggerAge() const int Application::fileLoggerAge() const
{ {
int val = settings()->loadValue(KEY_FILELOGGER_AGE, 1).toInt(); const int val = settings()->loadValue(KEY_FILELOGGER_AGE, 1).toInt();
return std::min(std::max(val, 1), 365); return std::min(std::max(val, 1), 365);
} }
@ -258,7 +258,7 @@ void Application::setFileLoggerAge(const int value)
int Application::fileLoggerAgeType() const int Application::fileLoggerAgeType() const
{ {
int val = settings()->loadValue(KEY_FILELOGGER_AGETYPE, 1).toInt(); const int val = settings()->loadValue(KEY_FILELOGGER_AGETYPE, 1).toInt();
return ((val < 0) || (val > 2)) ? 1 : val; return ((val < 0) || (val > 2)) ? 1 : val;
} }
@ -269,7 +269,7 @@ void Application::setFileLoggerAgeType(const int value)
void Application::processMessage(const QString &message) void Application::processMessage(const QString &message)
{ {
QStringList params = message.split(PARAMS_SEPARATOR, QString::SkipEmptyParts); const QStringList params = message.split(PARAMS_SEPARATOR, QString::SkipEmptyParts);
// If Application is not running (i.e., other // If Application is not running (i.e., other
// components are not ready) store params // components are not ready) store params
if (m_running) if (m_running)
@ -572,7 +572,7 @@ int Application::exec(const QStringList &params)
#ifdef Q_OS_WIN #ifdef Q_OS_WIN
bool Application::isRunning() bool Application::isRunning()
{ {
bool running = BaseApplication::isRunning(); const bool running = BaseApplication::isRunning();
QSharedMemory *sharedMem = new QSharedMemory(id() + QLatin1String("-shared-memory-key"), this); QSharedMemory *sharedMem = new QSharedMemory(id() + QLatin1String("-shared-memory-key"), this);
if (!running) { if (!running) {
// First instance creates shared memory and store PID // First instance creates shared memory and store PID
@ -622,7 +622,7 @@ void Application::initializeTranslation()
{ {
Preferences *const pref = Preferences::instance(); Preferences *const pref = Preferences::instance();
// Load translation // Load translation
QString localeStr = pref->getLocale(); const QString localeStr = pref->getLocale();
if (m_qtTranslator.load(QLatin1String("qtbase_") + localeStr, QLibraryInfo::location(QLibraryInfo::TranslationsPath)) || if (m_qtTranslator.load(QLatin1String("qtbase_") + localeStr, QLibraryInfo::location(QLibraryInfo::TranslationsPath)) ||
m_qtTranslator.load(QLatin1String("qt_") + localeStr, QLibraryInfo::location(QLibraryInfo::TranslationsPath))) m_qtTranslator.load(QLatin1String("qt_") + localeStr, QLibraryInfo::location(QLibraryInfo::TranslationsPath)))

View File

@ -99,11 +99,11 @@ public:
bool isFileLoggerDeleteOld() const; bool isFileLoggerDeleteOld() const;
void setFileLoggerDeleteOld(bool value); void setFileLoggerDeleteOld(bool value);
int fileLoggerMaxSize() const; int fileLoggerMaxSize() const;
void setFileLoggerMaxSize(const int bytes); void setFileLoggerMaxSize(int bytes);
int fileLoggerAge() const; int fileLoggerAge() const;
void setFileLoggerAge(const int value); void setFileLoggerAge(int value);
int fileLoggerAgeType() const; int fileLoggerAgeType() const;
void setFileLoggerAgeType(const int value); void setFileLoggerAgeType(int value);
protected: protected:
#ifndef DISABLE_GUI #ifndef DISABLE_GUI

View File

@ -276,7 +276,7 @@ namespace
TriStateBool value(const QProcessEnvironment &env) const TriStateBool value(const QProcessEnvironment &env) const
{ {
QString val = env.value(envVarName(), "-1"); const QString val = env.value(envVarName(), "-1");
if (val.isEmpty()) { if (val.isEmpty()) {
return TriStateBool(m_defaultValue); return TriStateBool(m_defaultValue);

View File

@ -85,8 +85,8 @@ void FileLogger::changePath(const QString &newPath)
void FileLogger::deleteOld(const int age, const FileLogAgeType ageType) void FileLogger::deleteOld(const int age, const FileLogAgeType ageType)
{ {
QDateTime date = QDateTime::currentDateTime(); const QDateTime date = QDateTime::currentDateTime();
QDir dir(Utils::Fs::branchPath(m_path)); const QDir dir(Utils::Fs::branchPath(m_path));
for (const QFileInfo &file : asConst(dir.entryInfoList(QStringList("qbittorrent.log.bak*"), QDir::Files | QDir::Writable, QDir::Time | QDir::Reversed))) { for (const QFileInfo &file : asConst(dir.entryInfoList(QStringList("qbittorrent.log.bak*"), QDir::Files | QDir::Writable, QDir::Time | QDir::Reversed))) {
QDateTime modificationDate = file.lastModified(); QDateTime modificationDate = file.lastModified();
@ -111,7 +111,7 @@ void FileLogger::setBackup(bool value)
m_backup = value; m_backup = value;
} }
void FileLogger::setMaxSize(int value) void FileLogger::setMaxSize(const int value)
{ {
m_maxSize = value; m_maxSize = value;
} }

View File

@ -52,11 +52,11 @@ public:
YEARS YEARS
}; };
FileLogger(const QString &path, const bool backup, const int maxSize, const bool deleteOld, const int age, const FileLogAgeType ageType); FileLogger(const QString &path, bool backup, int maxSize, bool deleteOld, int age, FileLogAgeType ageType);
~FileLogger(); ~FileLogger();
void changePath(const QString &newPath); void changePath(const QString &newPath);
void deleteOld(const int age, const FileLogAgeType ageType); void deleteOld(int age, FileLogAgeType ageType);
void setBackup(bool value); void setBackup(bool value);
void setMaxSize(int value); void setMaxSize(int value);

View File

@ -116,7 +116,7 @@ int main(int argc, char *argv[])
try { try {
// Create Application // Create Application
QString appId = QLatin1String("qBittorrent-") + Utils::Misc::getUserIDString(); const QString appId = QLatin1String("qBittorrent-") + Utils::Misc::getUserIDString();
QScopedPointer<Application> app(new Application(appId, argc, argv)); QScopedPointer<Application> app(new Application(appId, argc, argv));
const QBtCommandLineParameters params = app->commandLineArgs(); const QBtCommandLineParameters params = app->commandLineArgs();
@ -255,7 +255,7 @@ void reportToUser(const char *str)
{ {
const size_t strLen = strlen(str); const size_t strLen = strlen(str);
if (write(STDERR_FILENO, str, strLen) < static_cast<ssize_t>(strLen)) { if (write(STDERR_FILENO, str, strLen) < static_cast<ssize_t>(strLen)) {
auto dummy = write(STDOUT_FILENO, str, strLen); const auto dummy = write(STDOUT_FILENO, str, strLen);
Q_UNUSED(dummy); Q_UNUSED(dummy);
} }
} }
@ -305,7 +305,7 @@ void showSplashScreen()
{ {
QPixmap splashImg(":/icons/skin/splash.png"); QPixmap splashImg(":/icons/skin/splash.png");
QPainter painter(&splashImg); QPainter painter(&splashImg);
QString version = QBT_VERSION; const QString version = QBT_VERSION;
painter.setPen(QPen(Qt::white)); painter.setPen(QPen(Qt::white));
painter.setFont(QFont("Arial", 22, QFont::Black)); painter.setFont(QFont("Arial", 22, QFont::Black));
painter.drawText(224 - painter.fontMetrics().width(version), 270, version); painter.drawText(224 - painter.fontMetrics().width(version), 270, version);
@ -323,7 +323,7 @@ void displayVersion()
void displayBadArgMessage(const QString &message) void displayBadArgMessage(const QString &message)
{ {
QString help = QObject::tr("Run application with -h option to read about command line parameters."); const QString help = QObject::tr("Run application with -h option to read about command line parameters.");
#ifdef Q_OS_WIN #ifdef Q_OS_WIN
QMessageBox msgBox(QMessageBox::Critical, QObject::tr("Bad command line"), QMessageBox msgBox(QMessageBox::Critical, QObject::tr("Bad command line"),
message + QLatin1Char('\n') + help, QMessageBox::Ok); message + QLatin1Char('\n') + help, QMessageBox::Ok);
@ -351,7 +351,7 @@ bool userAgreesWithLegalNotice()
+ QObject::tr("Press %1 key to accept and continue...").arg("'y'") + '\n'; + QObject::tr("Press %1 key to accept and continue...").arg("'y'") + '\n';
printf("%s", qUtf8Printable(eula)); printf("%s", qUtf8Printable(eula));
char ret = getchar(); // Read pressed key const char ret = getchar(); // Read pressed key
if ((ret == 'y') || (ret == 'Y')) { if ((ret == 'y') || (ret == 'Y')) {
// Save the answer // Save the answer
pref->setAcceptedLegal(true); pref->setAcceptedLegal(true);
@ -362,7 +362,7 @@ bool userAgreesWithLegalNotice()
msgBox.setText(QObject::tr("qBittorrent is a file sharing program. When you run a torrent, its data will be made available to others by means of upload. Any content you share is your sole responsibility.\n\nNo further notices will be issued.")); msgBox.setText(QObject::tr("qBittorrent is a file sharing program. When you run a torrent, its data will be made available to others by means of upload. Any content you share is your sole responsibility.\n\nNo further notices will be issued."));
msgBox.setWindowTitle(QObject::tr("Legal notice")); msgBox.setWindowTitle(QObject::tr("Legal notice"));
msgBox.addButton(QObject::tr("Cancel"), QMessageBox::RejectRole); msgBox.addButton(QObject::tr("Cancel"), QMessageBox::RejectRole);
QAbstractButton *agreeButton = msgBox.addButton(QObject::tr("I Agree"), QMessageBox::AcceptRole); const QAbstractButton *agreeButton = msgBox.addButton(QObject::tr("I Agree"), QMessageBox::AcceptRole);
msgBox.show(); // Need to be shown or to moveToCenter does not work msgBox.show(); // Need to be shown or to moveToCenter does not work
msgBox.move(Utils::Misc::screenCenter(&msgBox)); msgBox.move(Utils::Misc::screenCenter(&msgBox));
msgBox.exec(); msgBox.exec();

View File

@ -43,7 +43,7 @@ PeerAddress::PeerAddress()
{ {
} }
PeerAddress::PeerAddress(QHostAddress ip, ushort port) PeerAddress::PeerAddress(const QHostAddress &ip, ushort port)
: ip(ip) : ip(ip)
, port(port) , port(port)
{ {

View File

@ -45,7 +45,7 @@ namespace BitTorrent
ushort port; ushort port;
PeerAddress(); PeerAddress();
PeerAddress(QHostAddress ip, ushort port); PeerAddress(const QHostAddress &ip, ushort port);
}; };
class PeerInfo class PeerInfo

View File

@ -93,7 +93,7 @@ bool BandwidthScheduler::isTimeForAlternative() const
void BandwidthScheduler::onTimeout() void BandwidthScheduler::onTimeout()
{ {
bool alternative = isTimeForAlternative(); const bool alternative = isTimeForAlternative();
if (alternative != m_lastAlternative) { if (alternative != m_lastAlternative) {
m_lastAlternative = alternative; m_lastAlternative = alternative;

View File

@ -50,7 +50,7 @@ namespace
char *endptr; char *endptr;
for (; *str; ++str) { for (; *str; ++str) {
if (*str == '.') { if (*str == '.') {
long int extractedNum = strtol(octetStart, &endptr, 10); const long int extractedNum = strtol(octetStart, &endptr, 10);
if ((extractedNum >= 0L) && (extractedNum <= 255L)) if ((extractedNum >= 0L) && (extractedNum <= 255L))
m_buf[octetIndex++] = static_cast<unsigned char>(extractedNum); m_buf[octetIndex++] = static_cast<unsigned char>(extractedNum);
else else
@ -66,7 +66,7 @@ namespace
} }
if (str != octetStart) { if (str != octetStart) {
long int extractedNum = strtol(octetStart, &endptr, 10); const long int extractedNum = strtol(octetStart, &endptr, 10);
if ((extractedNum >= 0L) && (extractedNum <= 255L)) if ((extractedNum >= 0L) && (extractedNum <= 255L))
m_buf[octetIndex] = static_cast<unsigned char>(strtol(octetStart, &endptr, 10)); m_buf[octetIndex] = static_cast<unsigned char>(strtol(octetStart, &endptr, 10));
else else
@ -146,7 +146,7 @@ int FilterParserThread::parseDATFilterFile()
bytesRead = file.read(buffer.data() + offset, BUFFER_SIZE - offset - 1); bytesRead = file.read(buffer.data() + offset, BUFFER_SIZE - offset - 1);
if (bytesRead < 0) if (bytesRead < 0)
break; break;
int dataSize = bytesRead + offset; const int dataSize = bytesRead + offset;
if ((bytesRead == 0) && (dataSize == 0)) if ((bytesRead == 0) && (dataSize == 0))
break; break;
@ -190,7 +190,7 @@ int FilterParserThread::parseDATFilterFile()
// Each line should follow this format: // Each line should follow this format:
// 001.009.096.105 - 001.009.096.105 , 000 , Some organization // 001.009.096.105 - 001.009.096.105 , 000 , Some organization
// The 3rd entry is access level and if above 127 the IP range isn't blocked. // The 3rd entry is access level and if above 127 the IP range isn't blocked.
int firstComma = findAndNullDelimiter(buffer.data(), ',', start, endOfLine); const int firstComma = findAndNullDelimiter(buffer.data(), ',', start, endOfLine);
if (firstComma != -1) if (firstComma != -1)
findAndNullDelimiter(buffer.data(), ',', firstComma + 1, endOfLine); findAndNullDelimiter(buffer.data(), ',', firstComma + 1, endOfLine);
@ -206,8 +206,8 @@ int FilterParserThread::parseDATFilterFile()
} }
// IP Range should be split by a dash // IP Range should be split by a dash
int endOfIPRange = ((firstComma == -1) ? (endOfLine - 1) : (firstComma - 1)); const int endOfIPRange = ((firstComma == -1) ? (endOfLine - 1) : (firstComma - 1));
int delimIP = findAndNullDelimiter(buffer.data(), '-', start, endOfIPRange); const int delimIP = findAndNullDelimiter(buffer.data(), '-', start, endOfIPRange);
if (delimIP == -1) { if (delimIP == -1) {
++parseErrorCount; ++parseErrorCount;
addLog(tr("IP filter line %1 is malformed.").arg(nbLine)); addLog(tr("IP filter line %1 is malformed.").arg(nbLine));
@ -294,7 +294,7 @@ int FilterParserThread::parseP2PFilterFile()
bytesRead = file.read(buffer.data() + offset, BUFFER_SIZE - offset - 1); bytesRead = file.read(buffer.data() + offset, BUFFER_SIZE - offset - 1);
if (bytesRead < 0) if (bytesRead < 0)
break; break;
int dataSize = bytesRead + offset; const int dataSize = bytesRead + offset;
if ((bytesRead == 0) && (dataSize == 0)) if ((bytesRead == 0) && (dataSize == 0))
break; break;
@ -338,7 +338,7 @@ int FilterParserThread::parseP2PFilterFile()
// Each line should follow this format: // Each line should follow this format:
// Some organization:1.0.0.0-1.255.255.255 // Some organization:1.0.0.0-1.255.255.255
// The "Some organization" part might contain a ':' char itself so we find the last occurrence // The "Some organization" part might contain a ':' char itself so we find the last occurrence
int partsDelimiter = findAndNullDelimiter(buffer.data(), ':', start, endOfLine, true); const int partsDelimiter = findAndNullDelimiter(buffer.data(), ':', start, endOfLine, true);
if (partsDelimiter == -1) { if (partsDelimiter == -1) {
++parseErrorCount; ++parseErrorCount;
addLog(tr("IP filter line %1 is malformed.").arg(nbLine)); addLog(tr("IP filter line %1 is malformed.").arg(nbLine));
@ -347,7 +347,7 @@ int FilterParserThread::parseP2PFilterFile()
} }
// IP Range should be split by a dash // IP Range should be split by a dash
int delimIP = findAndNullDelimiter(buffer.data(), '-', partsDelimiter + 1, endOfLine); const int delimIP = findAndNullDelimiter(buffer.data(), '-', partsDelimiter + 1, endOfLine);
if (delimIP == -1) { if (delimIP == -1) {
++parseErrorCount; ++parseErrorCount;
addLog(tr("IP filter line %1 is malformed.").arg(nbLine)); addLog(tr("IP filter line %1 is malformed.").arg(nbLine));
@ -404,7 +404,7 @@ int FilterParserThread::parseP2PFilterFile()
return ruleCount; return ruleCount;
} }
int FilterParserThread::getlineInStream(QDataStream &stream, std::string &name, char delim) int FilterParserThread::getlineInStream(QDataStream &stream, std::string &name, const char delim)
{ {
char c; char c;
int totalRead = 0; int totalRead = 0;
@ -465,8 +465,8 @@ int FilterParserThread::parseP2BFilterFile()
// Network byte order to Host byte order // Network byte order to Host byte order
// asio address_v4 constructor expects it // asio address_v4 constructor expects it
// that way // that way
libt::address_v4 first(ntohl(start)); const libt::address_v4 first(ntohl(start));
libt::address_v4 last(ntohl(end)); const libt::address_v4 last(ntohl(end));
// Apply to bittorrent session // Apply to bittorrent session
try { try {
m_filter.add_rule(first, last, libt::ip_filter::blocked); m_filter.add_rule(first, last, libt::ip_filter::blocked);
@ -515,8 +515,8 @@ int FilterParserThread::parseP2BFilterFile()
// Network byte order to Host byte order // Network byte order to Host byte order
// asio address_v4 constructor expects it // asio address_v4 constructor expects it
// that way // that way
libt::address_v4 first(ntohl(start)); const libt::address_v4 first(ntohl(start));
libt::address_v4 last(ntohl(end)); const libt::address_v4 last(ntohl(end));
// Apply to bittorrent session // Apply to bittorrent session
try { try {
m_filter.add_rule(first, last, libt::ip_filter::blocked); m_filter.add_rule(first, last, libt::ip_filter::blocked);
@ -588,7 +588,7 @@ void FilterParserThread::run()
qDebug("IP Filter thread: finished parsing, filter applied"); qDebug("IP Filter thread: finished parsing, filter applied");
} }
int FilterParserThread::findAndNullDelimiter(char *const data, char delimiter, int start, int end, bool reverse) int FilterParserThread::findAndNullDelimiter(char *const data, const char delimiter, const int start, const int end, const bool reverse)
{ {
if (!reverse) { if (!reverse) {
for (int i = start; i <= end; ++i) { for (int i = start; i <= end; ++i) {
@ -610,7 +610,7 @@ int FilterParserThread::findAndNullDelimiter(char *const data, char delimiter, i
return -1; return -1;
} }
int FilterParserThread::trim(char *const data, int start, int end) int FilterParserThread::trim(char *const data, const int start, const int end)
{ {
if (start >= end) return start; if (start >= end) return start;
int newStart = start; int newStart = start;

View File

@ -49,7 +49,7 @@ SpeedSampleAvg SpeedMonitor::average() const
if (m_speedSamples.empty()) if (m_speedSamples.empty())
return SpeedSampleAvg(); return SpeedSampleAvg();
qreal k = qreal(1.) / m_speedSamples.size(); const qreal k = qreal(1.) / m_speedSamples.size();
return SpeedSampleAvg(m_sum.download * k, m_sum.upload * k); return SpeedSampleAvg(m_sum.download * k, m_sum.upload * k);
} }

View File

@ -88,7 +88,7 @@ void Statistics::gather()
void Statistics::save() const void Statistics::save() const
{ {
qint64 now = QDateTime::currentMSecsSinceEpoch(); const qint64 now = QDateTime::currentMSecsSinceEpoch();
if (!m_dirty || ((now - m_lastWrite) < SAVE_INTERVAL)) if (!m_dirty || ((now - m_lastWrite) < SAVE_INTERVAL))
return; return;
@ -104,8 +104,8 @@ void Statistics::save() const
void Statistics::load() void Statistics::load()
{ {
SettingsPtr s = Profile::instance().applicationSettings(QLatin1String("qBittorrent-data")); const SettingsPtr s = Profile::instance().applicationSettings(QLatin1String("qBittorrent-data"));
QVariantHash v = s->value("Stats/AllStats").toHash(); const QVariantHash v = s->value("Stats/AllStats").toHash();
m_alltimeDL = v["AlltimeDL"].toULongLong(); m_alltimeDL = v["AlltimeDL"].toULongLong();
m_alltimeUL = v["AlltimeUL"].toULongLong(); m_alltimeUL = v["AlltimeUL"].toULongLong();

View File

@ -520,7 +520,7 @@ bool Session::isLSDEnabled() const
return m_isLSDEnabled; return m_isLSDEnabled;
} }
void Session::setLSDEnabled(bool enabled) void Session::setLSDEnabled(const bool enabled)
{ {
if (enabled != m_isLSDEnabled) { if (enabled != m_isLSDEnabled) {
m_isLSDEnabled = enabled; m_isLSDEnabled = enabled;
@ -536,7 +536,7 @@ bool Session::isPeXEnabled() const
return m_isPeXEnabled; return m_isPeXEnabled;
} }
void Session::setPeXEnabled(bool enabled) void Session::setPeXEnabled(const bool enabled)
{ {
m_isPeXEnabled = enabled; m_isPeXEnabled = enabled;
if (m_wasPexEnabled != enabled) if (m_wasPexEnabled != enabled)
@ -548,7 +548,7 @@ bool Session::isTempPathEnabled() const
return m_isTempPathEnabled; return m_isTempPathEnabled;
} }
void Session::setTempPathEnabled(bool enabled) void Session::setTempPathEnabled(const bool enabled)
{ {
if (enabled != isTempPathEnabled()) { if (enabled != isTempPathEnabled()) {
m_isTempPathEnabled = enabled; m_isTempPathEnabled = enabled;
@ -562,7 +562,7 @@ bool Session::isAppendExtensionEnabled() const
return m_isAppendExtensionEnabled; return m_isAppendExtensionEnabled;
} }
void Session::setAppendExtensionEnabled(bool enabled) void Session::setAppendExtensionEnabled(const bool enabled)
{ {
if (isAppendExtensionEnabled() != enabled) { if (isAppendExtensionEnabled() != enabled) {
// append or remove .!qB extension for incomplete files // append or remove .!qB extension for incomplete files
@ -578,7 +578,7 @@ uint Session::refreshInterval() const
return m_refreshInterval; return m_refreshInterval;
} }
void Session::setRefreshInterval(uint value) void Session::setRefreshInterval(const uint value)
{ {
if (value != refreshInterval()) { if (value != refreshInterval()) {
m_refreshTimer->setInterval(value); m_refreshTimer->setInterval(value);
@ -591,7 +591,7 @@ bool Session::isPreallocationEnabled() const
return m_isPreallocationEnabled; return m_isPreallocationEnabled;
} }
void Session::setPreallocationEnabled(bool enabled) void Session::setPreallocationEnabled(const bool enabled)
{ {
m_isPreallocationEnabled = enabled; m_isPreallocationEnabled = enabled;
} }
@ -674,7 +674,7 @@ const QStringMap &Session::categories() const
QString Session::categorySavePath(const QString &categoryName) const QString Session::categorySavePath(const QString &categoryName) const
{ {
QString basePath = m_defaultSavePath; const QString basePath = m_defaultSavePath;
if (categoryName.isEmpty()) return basePath; if (categoryName.isEmpty()) return basePath;
QString path = m_categories.value(categoryName); QString path = m_categories.value(categoryName);
@ -768,7 +768,7 @@ bool Session::isSubcategoriesEnabled() const
return m_isSubcategoriesEnabled; return m_isSubcategoriesEnabled;
} }
void Session::setSubcategoriesEnabled(bool value) void Session::setSubcategoriesEnabled(const bool value)
{ {
if (isSubcategoriesEnabled() == value) return; if (isSubcategoriesEnabled() == value) return;
@ -833,7 +833,7 @@ bool Session::isAutoTMMDisabledByDefault() const
return m_isAutoTMMDisabledByDefault; return m_isAutoTMMDisabledByDefault;
} }
void Session::setAutoTMMDisabledByDefault(bool value) void Session::setAutoTMMDisabledByDefault(const bool value)
{ {
m_isAutoTMMDisabledByDefault = value; m_isAutoTMMDisabledByDefault = value;
} }
@ -843,7 +843,7 @@ bool Session::isDisableAutoTMMWhenCategoryChanged() const
return m_isDisableAutoTMMWhenCategoryChanged; return m_isDisableAutoTMMWhenCategoryChanged;
} }
void Session::setDisableAutoTMMWhenCategoryChanged(bool value) void Session::setDisableAutoTMMWhenCategoryChanged(const bool value)
{ {
m_isDisableAutoTMMWhenCategoryChanged = value; m_isDisableAutoTMMWhenCategoryChanged = value;
} }
@ -853,7 +853,7 @@ bool Session::isDisableAutoTMMWhenDefaultSavePathChanged() const
return m_isDisableAutoTMMWhenDefaultSavePathChanged; return m_isDisableAutoTMMWhenDefaultSavePathChanged;
} }
void Session::setDisableAutoTMMWhenDefaultSavePathChanged(bool value) void Session::setDisableAutoTMMWhenDefaultSavePathChanged(const bool value)
{ {
m_isDisableAutoTMMWhenDefaultSavePathChanged = value; m_isDisableAutoTMMWhenDefaultSavePathChanged = value;
} }
@ -863,7 +863,7 @@ bool Session::isDisableAutoTMMWhenCategorySavePathChanged() const
return m_isDisableAutoTMMWhenCategorySavePathChanged; return m_isDisableAutoTMMWhenCategorySavePathChanged;
} }
void Session::setDisableAutoTMMWhenCategorySavePathChanged(bool value) void Session::setDisableAutoTMMWhenCategorySavePathChanged(const bool value)
{ {
m_isDisableAutoTMMWhenCategorySavePathChanged = value; m_isDisableAutoTMMWhenCategorySavePathChanged = value;
} }
@ -873,7 +873,7 @@ bool Session::isAddTorrentPaused() const
return m_isAddTorrentPaused; return m_isAddTorrentPaused;
} }
void Session::setAddTorrentPaused(bool value) void Session::setAddTorrentPaused(const bool value)
{ {
m_isAddTorrentPaused = value; m_isAddTorrentPaused = value;
} }
@ -883,7 +883,7 @@ bool Session::isTrackerEnabled() const
return m_isTrackerEnabled; return m_isTrackerEnabled;
} }
void Session::setTrackerEnabled(bool enabled) void Session::setTrackerEnabled(const bool enabled)
{ {
if (isTrackerEnabled() != enabled) { if (isTrackerEnabled() != enabled) {
enableTracker(enabled); enableTracker(enabled);
@ -1011,7 +1011,7 @@ void Session::processBannedIPs(libt::ip_filter &filter)
// First, import current filter // First, import current filter
for (const QString &ip : asConst(m_bannedIPs.value())) { for (const QString &ip : asConst(m_bannedIPs.value())) {
boost::system::error_code ec; boost::system::error_code ec;
libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec); const libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
Q_ASSERT(!ec); Q_ASSERT(!ec);
if (!ec) if (!ec)
filter.add_rule(addr, addr, libt::ip_filter::blocked); filter.add_rule(addr, addr, libt::ip_filter::blocked);
@ -1021,8 +1021,8 @@ void Session::processBannedIPs(libt::ip_filter &filter)
void Session::adjustLimits(libt::settings_pack &settingsPack) void Session::adjustLimits(libt::settings_pack &settingsPack)
{ {
// Internally increase the queue limits to ensure that the magnet is started // Internally increase the queue limits to ensure that the magnet is started
int maxDownloads = maxActiveDownloads(); const int maxDownloads = maxActiveDownloads();
int maxActive = maxActiveTorrents(); const int maxActive = maxActiveTorrents();
settingsPack.set_int(libt::settings_pack::active_downloads settingsPack.set_int(libt::settings_pack::active_downloads
, maxDownloads > -1 ? maxDownloads + m_extraLimit : maxDownloads); , maxDownloads > -1 ? maxDownloads + m_extraLimit : maxDownloads);
@ -1125,7 +1125,7 @@ void Session::configure(libtorrent::settings_pack &settingsPack)
if (m_listenInterfaceChanged) { if (m_listenInterfaceChanged) {
const ushort port = this->port(); const ushort port = this->port();
std::pair<int, int> ports(port, port); const std::pair<int, int> ports(port, port);
settingsPack.set_int(libt::settings_pack::max_retry_port_bind, ports.second - ports.first); settingsPack.set_int(libt::settings_pack::max_retry_port_bind, ports.second - ports.first);
for (QString ip : getListeningIPs()) { for (QString ip : getListeningIPs()) {
libt::error_code ec; libt::error_code ec;
@ -1143,7 +1143,7 @@ void Session::configure(libtorrent::settings_pack &settingsPack)
break; break;
} }
libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec); const libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
if (!ec) { if (!ec) {
interfacesStr = std::string((addr.is_v6() ? QString("[%1]:%2") : QString("%1:%2")) interfacesStr = std::string((addr.is_v6() ? QString("[%1]:%2") : QString("%1:%2"))
.arg(ip).arg(port).toLatin1().constData()); .arg(ip).arg(port).toLatin1().constData());
@ -1164,7 +1164,7 @@ void Session::configure(libtorrent::settings_pack &settingsPack)
// the interface's Luid and not the GUID. // the interface's Luid and not the GUID.
// Libtorrent expects GUIDs for the 'outgoing_interfaces' setting. // Libtorrent expects GUIDs for the 'outgoing_interfaces' setting.
if (!networkInterface().isEmpty()) { if (!networkInterface().isEmpty()) {
QString guid = convertIfaceNameToGuid(networkInterface()); const QString guid = convertIfaceNameToGuid(networkInterface());
if (!guid.isEmpty()) { if (!guid.isEmpty()) {
settingsPack.set_str(libt::settings_pack::outgoing_interfaces, guid.toStdString()); settingsPack.set_str(libt::settings_pack::outgoing_interfaces, guid.toStdString());
} }
@ -1199,8 +1199,8 @@ void Session::configure(libtorrent::settings_pack &settingsPack)
settingsPack.set_int(libt::settings_pack::in_enc_policy, libt::settings_pack::pe_disabled); settingsPack.set_int(libt::settings_pack::in_enc_policy, libt::settings_pack::pe_disabled);
} }
auto proxyManager = Net::ProxyConfigurationManager::instance(); const auto proxyManager = Net::ProxyConfigurationManager::instance();
Net::ProxyConfiguration proxyConfig = proxyManager->proxyConfiguration(); const Net::ProxyConfiguration proxyConfig = proxyManager->proxyConfiguration();
if (m_useProxy || (proxyConfig.type != Net::ProxyType::None)) { if (m_useProxy || (proxyConfig.type != Net::ProxyType::None)) {
if (proxyConfig.type != Net::ProxyType::None) { if (proxyConfig.type != Net::ProxyType::None) {
settingsPack.set_str(libt::settings_pack::proxy_hostname, proxyConfig.ip.toStdString()); settingsPack.set_str(libt::settings_pack::proxy_hostname, proxyConfig.ip.toStdString());
@ -1444,7 +1444,7 @@ void Session::configurePeerClasses()
m_nativeSession->set_peer_class_type_filter(peerClassTypeFilter); m_nativeSession->set_peer_class_type_filter(peerClassTypeFilter);
} }
void Session::enableTracker(bool enable) void Session::enableTracker(const bool enable)
{ {
Logger *const logger = Logger::instance(); Logger *const logger = Logger::instance();
@ -1596,7 +1596,7 @@ void Session::banIP(const QString &ip)
if (!bannedIPs.contains(ip)) { if (!bannedIPs.contains(ip)) {
libt::ip_filter filter = m_nativeSession->get_ip_filter(); libt::ip_filter filter = m_nativeSession->get_ip_filter();
boost::system::error_code ec; boost::system::error_code ec;
libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec); const libt::address addr = libt::address::from_string(ip.toLatin1().constData(), ec);
Q_ASSERT(!ec); Q_ASSERT(!ec);
if (ec) return; if (ec) return;
filter.add_rule(addr, addr, libt::ip_filter::blocked); filter.add_rule(addr, addr, libt::ip_filter::blocked);
@ -1610,7 +1610,7 @@ void Session::banIP(const QString &ip)
// Delete a torrent from the session, given its hash // Delete a torrent from the session, given its hash
// deleteLocalFiles = true means that the torrent will be removed from the hard-drive too // deleteLocalFiles = true means that the torrent will be removed from the hard-drive too
bool Session::deleteTorrent(const QString &hash, bool deleteLocalFiles) bool Session::deleteTorrent(const QString &hash, const bool deleteLocalFiles)
{ {
TorrentHandle *const torrent = m_torrents.take(hash); TorrentHandle *const torrent = m_torrents.take(hash);
if (!torrent) return false; if (!torrent) return false;
@ -1620,7 +1620,7 @@ bool Session::deleteTorrent(const QString &hash, bool deleteLocalFiles)
// Remove it from session // Remove it from session
if (deleteLocalFiles) { if (deleteLocalFiles) {
QString rootPath = torrent->rootPath(true); const QString rootPath = torrent->rootPath(true);
if (!rootPath.isEmpty()) if (!rootPath.isEmpty())
// torrent with root folder // torrent with root folder
m_removingTorrents[torrent->hash()] = {torrent->name(), rootPath, deleteLocalFiles}; m_removingTorrents[torrent->hash()] = {torrent->name(), rootPath, deleteLocalFiles};
@ -1648,7 +1648,7 @@ bool Session::deleteTorrent(const QString &hash, bool deleteLocalFiles)
} }
// Remove it from torrent resume directory // Remove it from torrent resume directory
QDir resumeDataDir(m_resumeFolderPath); const QDir resumeDataDir(m_resumeFolderPath);
QStringList filters; QStringList filters;
filters << QString("%1.*").arg(torrent->hash()); filters << QString("%1.*").arg(torrent->hash());
const QStringList files = resumeDataDir.entryList(filters, QDir::Files, QDir::Unsorted); const QStringList files = resumeDataDir.entryList(filters, QDir::Files, QDir::Unsorted);
@ -1665,7 +1665,7 @@ bool Session::cancelLoadMetadata(const InfoHash &hash)
if (!m_loadedMetadata.contains(hash)) return false; if (!m_loadedMetadata.contains(hash)) return false;
m_loadedMetadata.remove(hash); m_loadedMetadata.remove(hash);
libt::torrent_handle torrent = m_nativeSession->find_torrent(hash); const libt::torrent_handle torrent = m_nativeSession->find_torrent(hash);
if (!torrent.is_valid()) return false; if (!torrent.is_valid()) return false;
if (!torrent.status(0).has_metadata) { if (!torrent.status(0).has_metadata) {
@ -1795,7 +1795,7 @@ bool Session::addTorrent(const QString &source, const AddTorrentParams &params)
if (Net::DownloadManager::hasSupportedScheme(source)) { if (Net::DownloadManager::hasSupportedScheme(source)) {
LogMsg(tr("Downloading '%1', please wait...", "e.g: Downloading 'xxx.torrent', please wait...").arg(source)); LogMsg(tr("Downloading '%1', please wait...", "e.g: Downloading 'xxx.torrent', please wait...").arg(source));
// Launch downloader // Launch downloader
Net::DownloadHandler *handler = const Net::DownloadHandler *handler =
Net::DownloadManager::instance()->download(Net::DownloadRequest(source).limit(10485760 /* 10MB */).handleRedirectToMagnet(true)); Net::DownloadManager::instance()->download(Net::DownloadRequest(source).limit(10485760 /* 10MB */).handleRedirectToMagnet(true));
connect(handler, static_cast<void (Net::DownloadHandler::*)(const QString &, const QByteArray &)>(&Net::DownloadHandler::downloadFinished) connect(handler, static_cast<void (Net::DownloadHandler::*)(const QString &, const QByteArray &)>(&Net::DownloadHandler::downloadFinished)
, this, &Session::handleDownloadFinished); , this, &Session::handleDownloadFinished);
@ -1999,8 +1999,8 @@ bool Session::loadMetadata(const MagnetUri &magnetUri)
{ {
if (!magnetUri.isValid()) return false; if (!magnetUri.isValid()) return false;
InfoHash hash = magnetUri.hash(); const InfoHash hash = magnetUri.hash();
QString name = magnetUri.name(); const QString name = magnetUri.name();
// We should not add torrent if it's already // We should not add torrent if it's already
// processed or adding to session // processed or adding to session
@ -2052,11 +2052,11 @@ void Session::exportTorrentFile(TorrentHandle *const torrent, TorrentExportFolde
Q_ASSERT(((folder == TorrentExportFolder::Regular) && !torrentExportDirectory().isEmpty()) || Q_ASSERT(((folder == TorrentExportFolder::Regular) && !torrentExportDirectory().isEmpty()) ||
((folder == TorrentExportFolder::Finished) && !finishedTorrentExportDirectory().isEmpty())); ((folder == TorrentExportFolder::Finished) && !finishedTorrentExportDirectory().isEmpty()));
QString validName = Utils::Fs::toValidFileSystemName(torrent->name()); const QString validName = Utils::Fs::toValidFileSystemName(torrent->name());
QString torrentFilename = QString("%1.torrent").arg(torrent->hash()); const QString torrentFilename = QString("%1.torrent").arg(torrent->hash());
QString torrentExportFilename = QString("%1.torrent").arg(validName); QString torrentExportFilename = QString("%1.torrent").arg(validName);
QString torrentPath = QDir(m_resumeFolderPath).absoluteFilePath(torrentFilename); const QString torrentPath = QDir(m_resumeFolderPath).absoluteFilePath(torrentFilename);
QDir exportPath(folder == TorrentExportFolder::Regular ? torrentExportDirectory() : finishedTorrentExportDirectory()); const QDir exportPath(folder == TorrentExportFolder::Regular ? torrentExportDirectory() : finishedTorrentExportDirectory());
if (exportPath.exists() || exportPath.mkpath(exportPath.absolutePath())) { if (exportPath.exists() || exportPath.mkpath(exportPath.absolutePath())) {
QString newTorrentPath = exportPath.absoluteFilePath(torrentExportFilename); QString newTorrentPath = exportPath.absoluteFilePath(torrentExportFilename);
int counter = 0; int counter = 0;
@ -2071,7 +2071,7 @@ void Session::exportTorrentFile(TorrentHandle *const torrent, TorrentExportFolde
} }
} }
void Session::generateResumeData(bool final) void Session::generateResumeData(const bool final)
{ {
for (TorrentHandle *const torrent : asConst(m_torrents)) { for (TorrentHandle *const torrent : asConst(m_torrents)) {
if (!torrent->isValid()) continue; if (!torrent->isValid()) continue;
@ -2406,7 +2406,7 @@ bool Session::isBandwidthSchedulerEnabled() const
return m_isBandwidthSchedulerEnabled; return m_isBandwidthSchedulerEnabled;
} }
void Session::setBandwidthSchedulerEnabled(bool enabled) void Session::setBandwidthSchedulerEnabled(const bool enabled)
{ {
if (enabled != isBandwidthSchedulerEnabled()) { if (enabled != isBandwidthSchedulerEnabled()) {
m_isBandwidthSchedulerEnabled = enabled; m_isBandwidthSchedulerEnabled = enabled;
@ -2446,7 +2446,7 @@ int Session::port() const
return m_port; return m_port;
} }
void Session::setPort(int port) void Session::setPort(const int port)
{ {
if (port != this->port()) { if (port != this->port()) {
m_port = port; m_port = port;
@ -2459,7 +2459,7 @@ bool Session::useRandomPort() const
return m_useRandomPort; return m_useRandomPort;
} }
void Session::setUseRandomPort(bool value) void Session::setUseRandomPort(const bool value)
{ {
m_useRandomPort = value; m_useRandomPort = value;
} }
@ -2505,7 +2505,7 @@ bool Session::isIPv6Enabled() const
return m_isIPv6Enabled; return m_isIPv6Enabled;
} }
void Session::setIPv6Enabled(bool enabled) void Session::setIPv6Enabled(const bool enabled)
{ {
if (enabled != isIPv6Enabled()) { if (enabled != isIPv6Enabled()) {
m_isIPv6Enabled = enabled; m_isIPv6Enabled = enabled;
@ -2518,7 +2518,7 @@ int Session::encryption() const
return m_encryption; return m_encryption;
} }
void Session::setEncryption(int state) void Session::setEncryption(const int state)
{ {
if (state != encryption()) { if (state != encryption()) {
m_encryption = state; m_encryption = state;
@ -2535,7 +2535,7 @@ bool Session::isForceProxyEnabled() const
return m_isForceProxyEnabled; return m_isForceProxyEnabled;
} }
void Session::setForceProxyEnabled(bool enabled) void Session::setForceProxyEnabled(const bool enabled)
{ {
if (enabled != isForceProxyEnabled()) { if (enabled != isForceProxyEnabled()) {
m_isForceProxyEnabled = enabled; m_isForceProxyEnabled = enabled;
@ -2548,7 +2548,7 @@ bool Session::isProxyPeerConnectionsEnabled() const
return m_isProxyPeerConnectionsEnabled; return m_isProxyPeerConnectionsEnabled;
} }
void Session::setProxyPeerConnectionsEnabled(bool enabled) void Session::setProxyPeerConnectionsEnabled(const bool enabled)
{ {
if (enabled != isProxyPeerConnectionsEnabled()) { if (enabled != isProxyPeerConnectionsEnabled()) {
m_isProxyPeerConnectionsEnabled = enabled; m_isProxyPeerConnectionsEnabled = enabled;
@ -2561,7 +2561,7 @@ ChokingAlgorithm Session::chokingAlgorithm() const
return m_chokingAlgorithm; return m_chokingAlgorithm;
} }
void Session::setChokingAlgorithm(ChokingAlgorithm mode) void Session::setChokingAlgorithm(const ChokingAlgorithm mode)
{ {
if (mode == m_chokingAlgorithm) return; if (mode == m_chokingAlgorithm) return;
@ -2574,7 +2574,7 @@ SeedChokingAlgorithm Session::seedChokingAlgorithm() const
return m_seedChokingAlgorithm; return m_seedChokingAlgorithm;
} }
void Session::setSeedChokingAlgorithm(SeedChokingAlgorithm mode) void Session::setSeedChokingAlgorithm(const SeedChokingAlgorithm mode)
{ {
if (mode == m_seedChokingAlgorithm) return; if (mode == m_seedChokingAlgorithm) return;
@ -2587,7 +2587,7 @@ bool Session::isAddTrackersEnabled() const
return m_isAddTrackersEnabled; return m_isAddTrackersEnabled;
} }
void Session::setAddTrackersEnabled(bool enabled) void Session::setAddTrackersEnabled(const bool enabled)
{ {
m_isAddTrackersEnabled = enabled; m_isAddTrackersEnabled = enabled;
} }
@ -2610,7 +2610,7 @@ bool Session::isIPFilteringEnabled() const
return m_isIPFilteringEnabled; return m_isIPFilteringEnabled;
} }
void Session::setIPFilteringEnabled(bool enabled) void Session::setIPFilteringEnabled(const bool enabled)
{ {
if (enabled != m_isIPFilteringEnabled) { if (enabled != m_isIPFilteringEnabled) {
m_isIPFilteringEnabled = enabled; m_isIPFilteringEnabled = enabled;
@ -2722,7 +2722,7 @@ bool Session::announceToAllTrackers() const
return m_announceToAllTrackers; return m_announceToAllTrackers;
} }
void Session::setAnnounceToAllTrackers(bool val) void Session::setAnnounceToAllTrackers(const bool val)
{ {
if (val != m_announceToAllTrackers) { if (val != m_announceToAllTrackers) {
m_announceToAllTrackers = val; m_announceToAllTrackers = val;
@ -2735,7 +2735,7 @@ bool Session::announceToAllTiers() const
return m_announceToAllTiers; return m_announceToAllTiers;
} }
void Session::setAnnounceToAllTiers(bool val) void Session::setAnnounceToAllTiers(const bool val)
{ {
if (val != m_announceToAllTiers) { if (val != m_announceToAllTiers) {
m_announceToAllTiers = val; m_announceToAllTiers = val;
@ -2806,7 +2806,7 @@ int Session::diskCacheTTL() const
return m_diskCacheTTL; return m_diskCacheTTL;
} }
void Session::setDiskCacheTTL(int ttl) void Session::setDiskCacheTTL(const int ttl)
{ {
if (ttl != m_diskCacheTTL) { if (ttl != m_diskCacheTTL) {
m_diskCacheTTL = ttl; m_diskCacheTTL = ttl;
@ -2819,7 +2819,7 @@ bool Session::useOSCache() const
return m_useOSCache; return m_useOSCache;
} }
void Session::setUseOSCache(bool use) void Session::setUseOSCache(const bool use)
{ {
if (use != m_useOSCache) { if (use != m_useOSCache) {
m_useOSCache = use; m_useOSCache = use;
@ -2832,7 +2832,7 @@ bool Session::isGuidedReadCacheEnabled() const
return m_guidedReadCacheEnabled; return m_guidedReadCacheEnabled;
} }
void Session::setGuidedReadCacheEnabled(bool enabled) void Session::setGuidedReadCacheEnabled(const bool enabled)
{ {
if (enabled == m_guidedReadCacheEnabled) return; if (enabled == m_guidedReadCacheEnabled) return;
@ -2845,7 +2845,7 @@ bool Session::isCoalesceReadWriteEnabled() const
return m_coalesceReadWriteEnabled; return m_coalesceReadWriteEnabled;
} }
void Session::setCoalesceReadWriteEnabled(bool enabled) void Session::setCoalesceReadWriteEnabled(const bool enabled)
{ {
if (enabled == m_coalesceReadWriteEnabled) return; if (enabled == m_coalesceReadWriteEnabled) return;
@ -2858,7 +2858,7 @@ bool Session::isSuggestModeEnabled() const
return m_isSuggestMode; return m_isSuggestMode;
} }
void Session::setSuggestMode(bool mode) void Session::setSuggestMode(const bool mode)
{ {
if (mode == m_isSuggestMode) return; if (mode == m_isSuggestMode) return;
@ -2871,7 +2871,7 @@ int Session::sendBufferWatermark() const
return m_sendBufferWatermark; return m_sendBufferWatermark;
} }
void Session::setSendBufferWatermark(int value) void Session::setSendBufferWatermark(const int value)
{ {
if (value == m_sendBufferWatermark) return; if (value == m_sendBufferWatermark) return;
@ -2884,7 +2884,7 @@ int Session::sendBufferLowWatermark() const
return m_sendBufferLowWatermark; return m_sendBufferLowWatermark;
} }
void Session::setSendBufferLowWatermark(int value) void Session::setSendBufferLowWatermark(const int value)
{ {
if (value == m_sendBufferLowWatermark) return; if (value == m_sendBufferLowWatermark) return;
@ -2897,7 +2897,7 @@ int Session::sendBufferWatermarkFactor() const
return m_sendBufferWatermarkFactor; return m_sendBufferWatermarkFactor;
} }
void Session::setSendBufferWatermarkFactor(int value) void Session::setSendBufferWatermarkFactor(const int value)
{ {
if (value == m_sendBufferWatermarkFactor) return; if (value == m_sendBufferWatermarkFactor) return;
@ -2910,7 +2910,7 @@ bool Session::isAnonymousModeEnabled() const
return m_isAnonymousModeEnabled; return m_isAnonymousModeEnabled;
} }
void Session::setAnonymousModeEnabled(bool enabled) void Session::setAnonymousModeEnabled(const bool enabled)
{ {
if (enabled != m_isAnonymousModeEnabled) { if (enabled != m_isAnonymousModeEnabled) {
m_isAnonymousModeEnabled = enabled; m_isAnonymousModeEnabled = enabled;
@ -2926,7 +2926,7 @@ bool Session::isQueueingSystemEnabled() const
return m_isQueueingEnabled; return m_isQueueingEnabled;
} }
void Session::setQueueingSystemEnabled(bool enabled) void Session::setQueueingSystemEnabled(const bool enabled)
{ {
if (enabled != m_isQueueingEnabled) { if (enabled != m_isQueueingEnabled) {
m_isQueueingEnabled = enabled; m_isQueueingEnabled = enabled;
@ -2986,7 +2986,7 @@ bool Session::ignoreSlowTorrentsForQueueing() const
return m_ignoreSlowTorrentsForQueueing; return m_ignoreSlowTorrentsForQueueing;
} }
void Session::setIgnoreSlowTorrentsForQueueing(bool ignore) void Session::setIgnoreSlowTorrentsForQueueing(const bool ignore)
{ {
if (ignore != m_ignoreSlowTorrentsForQueueing) { if (ignore != m_ignoreSlowTorrentsForQueueing) {
m_ignoreSlowTorrentsForQueueing = ignore; m_ignoreSlowTorrentsForQueueing = ignore;
@ -2999,7 +2999,7 @@ int Session::downloadRateForSlowTorrents() const
return m_downloadRateForSlowTorrents; return m_downloadRateForSlowTorrents;
} }
void Session::setDownloadRateForSlowTorrents(int rateInKibiBytes) void Session::setDownloadRateForSlowTorrents(const int rateInKibiBytes)
{ {
if (rateInKibiBytes == m_downloadRateForSlowTorrents) if (rateInKibiBytes == m_downloadRateForSlowTorrents)
return; return;
@ -3013,7 +3013,7 @@ int Session::uploadRateForSlowTorrents() const
return m_uploadRateForSlowTorrents; return m_uploadRateForSlowTorrents;
} }
void Session::setUploadRateForSlowTorrents(int rateInKibiBytes) void Session::setUploadRateForSlowTorrents(const int rateInKibiBytes)
{ {
if (rateInKibiBytes == m_uploadRateForSlowTorrents) if (rateInKibiBytes == m_uploadRateForSlowTorrents)
return; return;
@ -3027,7 +3027,7 @@ int Session::slowTorrentsInactivityTimer() const
return m_slowTorrentsInactivityTimer; return m_slowTorrentsInactivityTimer;
} }
void Session::setSlowTorrentsInactivityTimer(int timeInSeconds) void Session::setSlowTorrentsInactivityTimer(const int timeInSeconds)
{ {
if (timeInSeconds == m_slowTorrentsInactivityTimer) if (timeInSeconds == m_slowTorrentsInactivityTimer)
return; return;
@ -3041,7 +3041,7 @@ int Session::outgoingPortsMin() const
return m_outgoingPortsMin; return m_outgoingPortsMin;
} }
void Session::setOutgoingPortsMin(int min) void Session::setOutgoingPortsMin(const int min)
{ {
if (min != m_outgoingPortsMin) { if (min != m_outgoingPortsMin) {
m_outgoingPortsMin = min; m_outgoingPortsMin = min;
@ -3054,7 +3054,7 @@ int Session::outgoingPortsMax() const
return m_outgoingPortsMax; return m_outgoingPortsMax;
} }
void Session::setOutgoingPortsMax(int max) void Session::setOutgoingPortsMax(const int max)
{ {
if (max != m_outgoingPortsMax) { if (max != m_outgoingPortsMax) {
m_outgoingPortsMax = max; m_outgoingPortsMax = max;
@ -3067,7 +3067,7 @@ bool Session::ignoreLimitsOnLAN() const
return m_ignoreLimitsOnLAN; return m_ignoreLimitsOnLAN;
} }
void Session::setIgnoreLimitsOnLAN(bool ignore) void Session::setIgnoreLimitsOnLAN(const bool ignore)
{ {
if (ignore != m_ignoreLimitsOnLAN) { if (ignore != m_ignoreLimitsOnLAN) {
m_ignoreLimitsOnLAN = ignore; m_ignoreLimitsOnLAN = ignore;
@ -3080,7 +3080,7 @@ bool Session::includeOverheadInLimits() const
return m_includeOverheadInLimits; return m_includeOverheadInLimits;
} }
void Session::setIncludeOverheadInLimits(bool include) void Session::setIncludeOverheadInLimits(const bool include)
{ {
if (include != m_includeOverheadInLimits) { if (include != m_includeOverheadInLimits) {
m_includeOverheadInLimits = include; m_includeOverheadInLimits = include;
@ -3106,7 +3106,7 @@ bool Session::isSuperSeedingEnabled() const
return m_isSuperSeedingEnabled; return m_isSuperSeedingEnabled;
} }
void Session::setSuperSeedingEnabled(bool enabled) void Session::setSuperSeedingEnabled(const bool enabled)
{ {
if (enabled != m_isSuperSeedingEnabled) { if (enabled != m_isSuperSeedingEnabled) {
m_isSuperSeedingEnabled = enabled; m_isSuperSeedingEnabled = enabled;
@ -3161,7 +3161,7 @@ BTProtocol Session::btProtocol() const
return m_btProtocol; return m_btProtocol;
} }
void Session::setBTProtocol(BTProtocol protocol) void Session::setBTProtocol(const BTProtocol protocol)
{ {
if ((protocol < BTProtocol::Both) || (BTProtocol::UTP < protocol)) if ((protocol < BTProtocol::Both) || (BTProtocol::UTP < protocol))
return; return;
@ -3177,7 +3177,7 @@ bool Session::isUTPRateLimited() const
return m_isUTPRateLimited; return m_isUTPRateLimited;
} }
void Session::setUTPRateLimited(bool limited) void Session::setUTPRateLimited(const bool limited)
{ {
if (limited != m_isUTPRateLimited) { if (limited != m_isUTPRateLimited) {
m_isUTPRateLimited = limited; m_isUTPRateLimited = limited;
@ -3190,7 +3190,7 @@ MixedModeAlgorithm Session::utpMixedMode() const
return m_utpMixedMode; return m_utpMixedMode;
} }
void Session::setUtpMixedMode(MixedModeAlgorithm mode) void Session::setUtpMixedMode(const MixedModeAlgorithm mode)
{ {
if (mode == m_utpMixedMode) return; if (mode == m_utpMixedMode) return;
@ -3203,7 +3203,7 @@ bool Session::multiConnectionsPerIpEnabled() const
return m_multiConnectionsPerIpEnabled; return m_multiConnectionsPerIpEnabled;
} }
void Session::setMultiConnectionsPerIpEnabled(bool enabled) void Session::setMultiConnectionsPerIpEnabled(const bool enabled)
{ {
if (enabled == m_multiConnectionsPerIpEnabled) return; if (enabled == m_multiConnectionsPerIpEnabled) return;
@ -3216,7 +3216,7 @@ bool Session::isTrackerFilteringEnabled() const
return m_isTrackerFilteringEnabled; return m_isTrackerFilteringEnabled;
} }
void Session::setTrackerFilteringEnabled(bool enabled) void Session::setTrackerFilteringEnabled(const bool enabled)
{ {
if (enabled != m_isTrackerFilteringEnabled) { if (enabled != m_isTrackerFilteringEnabled) {
m_isTrackerFilteringEnabled = enabled; m_isTrackerFilteringEnabled = enabled;
@ -3234,7 +3234,7 @@ MaxRatioAction Session::maxRatioAction() const
return static_cast<MaxRatioAction>(m_maxRatioAction.value()); return static_cast<MaxRatioAction>(m_maxRatioAction.value());
} }
void Session::setMaxRatioAction(MaxRatioAction act) void Session::setMaxRatioAction(const MaxRatioAction act)
{ {
m_maxRatioAction = static_cast<int>(act); m_maxRatioAction = static_cast<int>(act);
} }
@ -3477,7 +3477,7 @@ bool Session::hasPerTorrentSeedingTimeLimit() const
void Session::initResumeFolder() void Session::initResumeFolder()
{ {
m_resumeFolderPath = Utils::Fs::expandPathAbs(specialFolderLocation(SpecialFolder::Data) + RESUME_FOLDER); m_resumeFolderPath = Utils::Fs::expandPathAbs(specialFolderLocation(SpecialFolder::Data) + RESUME_FOLDER);
QDir resumeFolderDir(m_resumeFolderPath); const QDir resumeFolderDir(m_resumeFolderPath);
if (resumeFolderDir.exists() || resumeFolderDir.mkpath(resumeFolderDir.absolutePath())) { if (resumeFolderDir.exists() || resumeFolderDir.mkpath(resumeFolderDir.absolutePath())) {
m_resumeFolderLock.setFileName(resumeFolderDir.absoluteFilePath("session.lock")); m_resumeFolderLock.setFileName(resumeFolderDir.absoluteFilePath("session.lock"));
if (!m_resumeFolderLock.open(QFile::WriteOnly)) { if (!m_resumeFolderLock.open(QFile::WriteOnly)) {
@ -3519,7 +3519,7 @@ void Session::disableIPFilter()
{ {
qDebug("Disabling IPFilter"); qDebug("Disabling IPFilter");
if (m_filterParser) { if (m_filterParser) {
disconnect(m_filterParser.data(), 0, this, 0); disconnect(m_filterParser.data(), nullptr, this, nullptr);
delete m_filterParser; delete m_filterParser;
} }
@ -3585,7 +3585,7 @@ void Session::startUpTorrents()
int resumedTorrentsCount = 0; int resumedTorrentsCount = 0;
const auto startupTorrent = [this, logger, &resumeDataDir, &resumedTorrentsCount](const TorrentResumeData &params) const auto startupTorrent = [this, logger, &resumeDataDir, &resumedTorrentsCount](const TorrentResumeData &params)
{ {
QString filePath = resumeDataDir.filePath(QString("%1.torrent").arg(params.hash)); const QString filePath = resumeDataDir.filePath(QString("%1.torrent").arg(params.hash));
qDebug() << "Starting up torrent" << params.hash << "..."; qDebug() << "Starting up torrent" << params.hash << "...";
if (!addTorrent_impl(params.addTorrentData, params.magnetUri, TorrentInfo::loadFromFile(filePath), params.data)) if (!addTorrent_impl(params.addTorrentData, params.magnetUri, TorrentInfo::loadFromFile(filePath), params.data))
logger->addMessage(tr("Unable to resume torrent '%1'.", "e.g: Unable to resume torrent 'hash'.") logger->addMessage(tr("Unable to resume torrent '%1'.", "e.g: Unable to resume torrent 'hash'.")
@ -3706,7 +3706,7 @@ void Session::refresh()
m_nativeSession->post_session_stats(); m_nativeSession->post_session_stats();
} }
void Session::handleIPFilterParsed(int ruleCount) void Session::handleIPFilterParsed(const int ruleCount)
{ {
if (m_filterParser) { if (m_filterParser) {
libt::ip_filter filter = m_filterParser->IPfilter(); libt::ip_filter filter = m_filterParser->IPfilter();
@ -3727,7 +3727,7 @@ void Session::handleIPFilterError()
emit IPFilterParsed(true, 0); emit IPFilterParsed(true, 0);
} }
void Session::getPendingAlerts(std::vector<libt::alert *> &out, ulong time) void Session::getPendingAlerts(std::vector<libt::alert *> &out, const ulong time)
{ {
Q_ASSERT(out.empty()); Q_ASSERT(out.empty());
@ -3741,7 +3741,7 @@ bool Session::isCreateTorrentSubfolder() const
return m_isCreateTorrentSubfolder; return m_isCreateTorrentSubfolder;
} }
void Session::setCreateTorrentSubfolder(bool value) void Session::setCreateTorrentSubfolder(const bool value)
{ {
m_isCreateTorrentSubfolder = value; m_isCreateTorrentSubfolder = value;
} }
@ -3756,7 +3756,7 @@ void Session::readAlerts()
handleAlert(a); handleAlert(a);
} }
void Session::handleAlert(libt::alert *a) void Session::handleAlert(const libt::alert *a)
{ {
try { try {
switch (a->type()) { switch (a->type()) {
@ -3778,53 +3778,53 @@ void Session::handleAlert(libt::alert *a)
dispatchTorrentAlert(a); dispatchTorrentAlert(a);
break; break;
case libt::metadata_received_alert::alert_type: case libt::metadata_received_alert::alert_type:
handleMetadataReceivedAlert(static_cast<libt::metadata_received_alert*>(a)); handleMetadataReceivedAlert(static_cast<const libt::metadata_received_alert*>(a));
dispatchTorrentAlert(a); dispatchTorrentAlert(a);
break; break;
case libt::state_update_alert::alert_type: case libt::state_update_alert::alert_type:
handleStateUpdateAlert(static_cast<libt::state_update_alert*>(a)); handleStateUpdateAlert(static_cast<const libt::state_update_alert*>(a));
break; break;
case libt::session_stats_alert::alert_type: case libt::session_stats_alert::alert_type:
handleSessionStatsAlert(static_cast<libt::session_stats_alert*>(a)); handleSessionStatsAlert(static_cast<const libt::session_stats_alert*>(a));
break; break;
case libt::file_error_alert::alert_type: case libt::file_error_alert::alert_type:
handleFileErrorAlert(static_cast<libt::file_error_alert*>(a)); handleFileErrorAlert(static_cast<const libt::file_error_alert*>(a));
break; break;
case libt::add_torrent_alert::alert_type: case libt::add_torrent_alert::alert_type:
handleAddTorrentAlert(static_cast<libt::add_torrent_alert*>(a)); handleAddTorrentAlert(static_cast<const libt::add_torrent_alert*>(a));
break; break;
case libt::torrent_removed_alert::alert_type: case libt::torrent_removed_alert::alert_type:
handleTorrentRemovedAlert(static_cast<libt::torrent_removed_alert*>(a)); handleTorrentRemovedAlert(static_cast<const libt::torrent_removed_alert*>(a));
break; break;
case libt::torrent_deleted_alert::alert_type: case libt::torrent_deleted_alert::alert_type:
handleTorrentDeletedAlert(static_cast<libt::torrent_deleted_alert*>(a)); handleTorrentDeletedAlert(static_cast<const libt::torrent_deleted_alert*>(a));
break; break;
case libt::torrent_delete_failed_alert::alert_type: case libt::torrent_delete_failed_alert::alert_type:
handleTorrentDeleteFailedAlert(static_cast<libt::torrent_delete_failed_alert*>(a)); handleTorrentDeleteFailedAlert(static_cast<const libt::torrent_delete_failed_alert*>(a));
break; break;
case libt::portmap_error_alert::alert_type: case libt::portmap_error_alert::alert_type:
handlePortmapWarningAlert(static_cast<libt::portmap_error_alert*>(a)); handlePortmapWarningAlert(static_cast<const libt::portmap_error_alert*>(a));
break; break;
case libt::portmap_alert::alert_type: case libt::portmap_alert::alert_type:
handlePortmapAlert(static_cast<libt::portmap_alert*>(a)); handlePortmapAlert(static_cast<const libt::portmap_alert*>(a));
break; break;
case libt::peer_blocked_alert::alert_type: case libt::peer_blocked_alert::alert_type:
handlePeerBlockedAlert(static_cast<libt::peer_blocked_alert*>(a)); handlePeerBlockedAlert(static_cast<const libt::peer_blocked_alert*>(a));
break; break;
case libt::peer_ban_alert::alert_type: case libt::peer_ban_alert::alert_type:
handlePeerBanAlert(static_cast<libt::peer_ban_alert*>(a)); handlePeerBanAlert(static_cast<const libt::peer_ban_alert*>(a));
break; break;
case libt::url_seed_alert::alert_type: case libt::url_seed_alert::alert_type:
handleUrlSeedAlert(static_cast<libt::url_seed_alert*>(a)); handleUrlSeedAlert(static_cast<const libt::url_seed_alert*>(a));
break; break;
case libt::listen_succeeded_alert::alert_type: case libt::listen_succeeded_alert::alert_type:
handleListenSucceededAlert(static_cast<libt::listen_succeeded_alert*>(a)); handleListenSucceededAlert(static_cast<const libt::listen_succeeded_alert*>(a));
break; break;
case libt::listen_failed_alert::alert_type: case libt::listen_failed_alert::alert_type:
handleListenFailedAlert(static_cast<libt::listen_failed_alert*>(a)); handleListenFailedAlert(static_cast<const libt::listen_failed_alert*>(a));
break; break;
case libt::external_ip_alert::alert_type: case libt::external_ip_alert::alert_type:
handleExternalIPAlert(static_cast<libt::external_ip_alert*>(a)); handleExternalIPAlert(static_cast<const libt::external_ip_alert*>(a));
break; break;
} }
} }
@ -3833,9 +3833,9 @@ void Session::handleAlert(libt::alert *a)
} }
} }
void Session::dispatchTorrentAlert(libt::alert *a) void Session::dispatchTorrentAlert(const libt::alert *a)
{ {
TorrentHandle *const torrent = m_torrents.value(static_cast<libt::torrent_alert*>(a)->handle.info_hash()); TorrentHandle *const torrent = m_torrents.value(static_cast<const libt::torrent_alert*>(a)->handle.info_hash());
if (torrent) if (torrent)
torrent->handleAlert(a); torrent->handleAlert(a);
} }
@ -3845,14 +3845,14 @@ void Session::createTorrentHandle(const libt::torrent_handle &nativeHandle)
// Magnet added for preload its metadata // Magnet added for preload its metadata
if (!m_addingTorrents.contains(nativeHandle.info_hash())) return; if (!m_addingTorrents.contains(nativeHandle.info_hash())) return;
CreateTorrentParams params = m_addingTorrents.take(nativeHandle.info_hash()); const CreateTorrentParams params = m_addingTorrents.take(nativeHandle.info_hash());
TorrentHandle *const torrent = new TorrentHandle(this, nativeHandle, params); TorrentHandle *const torrent = new TorrentHandle(this, nativeHandle, params);
m_torrents.insert(torrent->hash(), torrent); m_torrents.insert(torrent->hash(), torrent);
Logger *const logger = Logger::instance(); Logger *const logger = Logger::instance();
bool fromMagnetUri = !torrent->hasMetadata(); const bool fromMagnetUri = !torrent->hasMetadata();
if (params.restored) { if (params.restored) {
logger->addMessage(tr("'%1' restored.", "'torrent name' restored.").arg(torrent->name())); logger->addMessage(tr("'%1' restored.", "'torrent name' restored.").arg(torrent->name()));
@ -3895,7 +3895,7 @@ void Session::createTorrentHandle(const libt::torrent_handle &nativeHandle)
emit torrentNew(torrent); emit torrentNew(torrent);
} }
void Session::handleAddTorrentAlert(libt::add_torrent_alert *p) void Session::handleAddTorrentAlert(const libt::add_torrent_alert *p)
{ {
if (p->error) { if (p->error) {
qDebug("/!\\ Error: Failed to add torrent!"); qDebug("/!\\ Error: Failed to add torrent!");
@ -3908,7 +3908,7 @@ void Session::handleAddTorrentAlert(libt::add_torrent_alert *p)
} }
} }
void Session::handleTorrentRemovedAlert(libt::torrent_removed_alert *p) void Session::handleTorrentRemovedAlert(const libt::torrent_removed_alert *p)
{ {
const InfoHash infoHash {p->info_hash}; const InfoHash infoHash {p->info_hash};
@ -3924,7 +3924,7 @@ void Session::handleTorrentRemovedAlert(libt::torrent_removed_alert *p)
} }
} }
void Session::handleTorrentDeletedAlert(libt::torrent_deleted_alert *p) void Session::handleTorrentDeletedAlert(const libt::torrent_deleted_alert *p)
{ {
const InfoHash infoHash {p->info_hash}; const InfoHash infoHash {p->info_hash};
@ -3936,7 +3936,7 @@ void Session::handleTorrentDeletedAlert(libt::torrent_deleted_alert *p)
LogMsg(tr("'%1' was removed from the transfer list and hard disk.", "'xxx.avi' was removed...").arg(tmpRemovingTorrentData.name)); LogMsg(tr("'%1' was removed from the transfer list and hard disk.", "'xxx.avi' was removed...").arg(tmpRemovingTorrentData.name));
} }
void Session::handleTorrentDeleteFailedAlert(libt::torrent_delete_failed_alert *p) void Session::handleTorrentDeleteFailedAlert(const libt::torrent_delete_failed_alert *p)
{ {
const InfoHash infoHash {p->info_hash}; const InfoHash infoHash {p->info_hash};
@ -3952,7 +3952,7 @@ void Session::handleTorrentDeleteFailedAlert(libt::torrent_delete_failed_alert *
, Log::CRITICAL); , Log::CRITICAL);
} }
void Session::handleMetadataReceivedAlert(libt::metadata_received_alert *p) void Session::handleMetadataReceivedAlert(const libt::metadata_received_alert *p)
{ {
const InfoHash hash {p->handle.info_hash()}; const InfoHash hash {p->handle.info_hash()};
@ -3964,7 +3964,7 @@ void Session::handleMetadataReceivedAlert(libt::metadata_received_alert *p)
} }
} }
void Session::handleFileErrorAlert(libt::file_error_alert *p) void Session::handleFileErrorAlert(const libt::file_error_alert *p)
{ {
qDebug() << Q_FUNC_INFO; qDebug() << Q_FUNC_INFO;
// NOTE: Check this function! // NOTE: Check this function!
@ -3982,21 +3982,21 @@ void Session::handleFileErrorAlert(libt::file_error_alert *p)
} }
} }
void Session::handlePortmapWarningAlert(libt::portmap_error_alert *p) void Session::handlePortmapWarningAlert(const libt::portmap_error_alert *p)
{ {
Logger::instance()->addMessage(tr("UPnP/NAT-PMP: Port mapping failure, message: %1").arg(QString::fromStdString(p->message())), Log::CRITICAL); Logger::instance()->addMessage(tr("UPnP/NAT-PMP: Port mapping failure, message: %1").arg(QString::fromStdString(p->message())), Log::CRITICAL);
} }
void Session::handlePortmapAlert(libt::portmap_alert *p) void Session::handlePortmapAlert(const libt::portmap_alert *p)
{ {
qDebug("UPnP Success, msg: %s", p->message().c_str()); qDebug("UPnP Success, msg: %s", p->message().c_str());
Logger::instance()->addMessage(tr("UPnP/NAT-PMP: Port mapping successful, message: %1").arg(QString::fromStdString(p->message())), Log::INFO); Logger::instance()->addMessage(tr("UPnP/NAT-PMP: Port mapping successful, message: %1").arg(QString::fromStdString(p->message())), Log::INFO);
} }
void Session::handlePeerBlockedAlert(libt::peer_blocked_alert *p) void Session::handlePeerBlockedAlert(const libt::peer_blocked_alert *p)
{ {
boost::system::error_code ec; boost::system::error_code ec;
std::string ip = p->ip.to_string(ec); const std::string ip = p->ip.to_string(ec);
QString reason; QString reason;
switch (p->reason) { switch (p->reason) {
case libt::peer_blocked_alert::ip_filter: case libt::peer_blocked_alert::ip_filter:
@ -4023,22 +4023,22 @@ void Session::handlePeerBlockedAlert(libt::peer_blocked_alert *p)
Logger::instance()->addPeer(QString::fromLatin1(ip.c_str()), true, reason); Logger::instance()->addPeer(QString::fromLatin1(ip.c_str()), true, reason);
} }
void Session::handlePeerBanAlert(libt::peer_ban_alert *p) void Session::handlePeerBanAlert(const libt::peer_ban_alert *p)
{ {
boost::system::error_code ec; boost::system::error_code ec;
std::string ip = p->ip.address().to_string(ec); const std::string ip = p->ip.address().to_string(ec);
if (!ec) if (!ec)
Logger::instance()->addPeer(QString::fromLatin1(ip.c_str()), false); Logger::instance()->addPeer(QString::fromLatin1(ip.c_str()), false);
} }
void Session::handleUrlSeedAlert(libt::url_seed_alert *p) void Session::handleUrlSeedAlert(const libt::url_seed_alert *p)
{ {
Logger::instance()->addMessage(tr("URL seed lookup failed for URL: '%1', message: %2") Logger::instance()->addMessage(tr("URL seed lookup failed for URL: '%1', message: %2")
.arg(QString::fromStdString(p->server_url())) .arg(QString::fromStdString(p->server_url()))
.arg(QString::fromStdString(p->message())), Log::CRITICAL); .arg(QString::fromStdString(p->message())), Log::CRITICAL);
} }
void Session::handleListenSucceededAlert(libt::listen_succeeded_alert *p) void Session::handleListenSucceededAlert(const libt::listen_succeeded_alert *p)
{ {
boost::system::error_code ec; boost::system::error_code ec;
QString proto = "TCP"; QString proto = "TCP";
@ -4061,7 +4061,7 @@ void Session::handleListenSucceededAlert(libt::listen_succeeded_alert *p)
it->force_reannounce(); it->force_reannounce();
} }
void Session::handleListenFailedAlert(libt::listen_failed_alert *p) void Session::handleListenFailedAlert(const libt::listen_failed_alert *p)
{ {
boost::system::error_code ec; boost::system::error_code ec;
QString proto = "TCP"; QString proto = "TCP";
@ -4084,15 +4084,15 @@ void Session::handleListenFailedAlert(libt::listen_failed_alert *p)
, Log::CRITICAL); , Log::CRITICAL);
} }
void Session::handleExternalIPAlert(libt::external_ip_alert *p) void Session::handleExternalIPAlert(const libt::external_ip_alert *p)
{ {
boost::system::error_code ec; boost::system::error_code ec;
Logger::instance()->addMessage(tr("External IP: %1", "e.g. External IP: 192.168.0.1").arg(p->external_address.to_string(ec).c_str()), Log::INFO); Logger::instance()->addMessage(tr("External IP: %1", "e.g. External IP: 192.168.0.1").arg(p->external_address.to_string(ec).c_str()), Log::INFO);
} }
void Session::handleSessionStatsAlert(libt::session_stats_alert *p) void Session::handleSessionStatsAlert(const libt::session_stats_alert *p)
{ {
qreal interval = m_statsUpdateTimer.restart() / 1000.; const qreal interval = m_statsUpdateTimer.restart() / 1000.;
m_status.hasIncomingConnections = static_cast<bool>(p->values[m_metricIndices.net.hasIncomingConnections]); m_status.hasIncomingConnections = static_cast<bool>(p->values[m_metricIndices.net.hasIncomingConnections]);
@ -4107,7 +4107,7 @@ void Session::handleSessionStatsAlert(libt::session_stats_alert *p)
const auto dhtDownload = p->values[m_metricIndices.dht.dhtBytesIn]; const auto dhtDownload = p->values[m_metricIndices.dht.dhtBytesIn];
const auto dhtUpload = p->values[m_metricIndices.dht.dhtBytesOut]; const auto dhtUpload = p->values[m_metricIndices.dht.dhtBytesOut];
auto calcRate = [interval](quint64 previous, quint64 current) auto calcRate = [interval](const quint64 previous, const quint64 current)
{ {
Q_ASSERT(current >= previous); Q_ASSERT(current >= previous);
return static_cast<quint64>((current - previous) / interval); return static_cast<quint64>((current - previous) / interval);
@ -4147,7 +4147,7 @@ void Session::handleSessionStatsAlert(libt::session_stats_alert *p)
m_cacheStatus.readRatio = static_cast<qreal>(numBlocksCacheHits) / std::max(numBlocksCacheHits + numBlocksRead, 1); m_cacheStatus.readRatio = static_cast<qreal>(numBlocksCacheHits) / std::max(numBlocksCacheHits + numBlocksRead, 1);
m_cacheStatus.jobQueueLength = p->values[m_metricIndices.disk.queuedDiskJobs]; m_cacheStatus.jobQueueLength = p->values[m_metricIndices.disk.queuedDiskJobs];
quint64 totalJobs = p->values[m_metricIndices.disk.writeJobs] + p->values[m_metricIndices.disk.readJobs] const quint64 totalJobs = p->values[m_metricIndices.disk.writeJobs] + p->values[m_metricIndices.disk.readJobs]
+ p->values[m_metricIndices.disk.hashJobs]; + p->values[m_metricIndices.disk.hashJobs];
m_cacheStatus.averageJobTime = totalJobs > 0 m_cacheStatus.averageJobTime = totalJobs > 0
? (p->values[m_metricIndices.disk.diskJobTime] / totalJobs) : 0; ? (p->values[m_metricIndices.disk.diskJobTime] / totalJobs) : 0;
@ -4155,7 +4155,7 @@ void Session::handleSessionStatsAlert(libt::session_stats_alert *p)
emit statsUpdated(); emit statsUpdated();
} }
void Session::handleStateUpdateAlert(libt::state_update_alert *p) void Session::handleStateUpdateAlert(const libt::state_update_alert *p)
{ {
for (const libt::torrent_status &status : p->status) { for (const libt::torrent_status &status : p->status) {
TorrentHandle *const torrent = m_torrents.value(status.info_hash); TorrentHandle *const torrent = m_torrents.value(status.info_hash);
@ -4306,7 +4306,7 @@ namespace
if (!ConvertIfaceLuidToGuid) return QString(); if (!ConvertIfaceLuidToGuid) return QString();
NET_LUID luid; NET_LUID luid;
LONG res = ConvertIfaceNameToLuid(name.toStdWString().c_str(), &luid); const LONG res = ConvertIfaceNameToLuid(name.toStdWString().c_str(), &luid);
if (res == 0) { if (res == 0) {
GUID guid; GUID guid;
if (ConvertIfaceLuidToGuid(&luid, &guid) == 0) if (ConvertIfaceLuidToGuid(&luid, &guid) == 0)

View File

@ -542,7 +542,7 @@ namespace BitTorrent
void handleRedirectedToMagnet(const QString &url, const QString &magnetUri); void handleRedirectedToMagnet(const QString &url, const QString &magnetUri);
// Session reconfiguration triggers // Session reconfiguration triggers
void networkOnlineStateChanged(const bool online); void networkOnlineStateChanged(bool online);
void networkConfigurationChange(const QNetworkConfiguration&); void networkConfigurationChange(const QNetworkConfiguration&);
private: private:
@ -588,24 +588,24 @@ namespace BitTorrent
void exportTorrentFile(TorrentHandle *const torrent, TorrentExportFolder folder = TorrentExportFolder::Regular); void exportTorrentFile(TorrentHandle *const torrent, TorrentExportFolder folder = TorrentExportFolder::Regular);
void saveTorrentResumeData(TorrentHandle *const torrent); void saveTorrentResumeData(TorrentHandle *const torrent);
void handleAlert(libtorrent::alert *a); void handleAlert(const libtorrent::alert *a);
void dispatchTorrentAlert(libtorrent::alert *a); void dispatchTorrentAlert(const libtorrent::alert *a);
void handleAddTorrentAlert(libtorrent::add_torrent_alert *p); void handleAddTorrentAlert(const libtorrent::add_torrent_alert *p);
void handleStateUpdateAlert(libtorrent::state_update_alert *p); void handleStateUpdateAlert(const libtorrent::state_update_alert *p);
void handleMetadataReceivedAlert(libtorrent::metadata_received_alert *p); void handleMetadataReceivedAlert(const libtorrent::metadata_received_alert *p);
void handleFileErrorAlert(libtorrent::file_error_alert *p); void handleFileErrorAlert(const libtorrent::file_error_alert *p);
void handleTorrentRemovedAlert(libtorrent::torrent_removed_alert *p); void handleTorrentRemovedAlert(const libtorrent::torrent_removed_alert *p);
void handleTorrentDeletedAlert(libtorrent::torrent_deleted_alert *p); void handleTorrentDeletedAlert(const libtorrent::torrent_deleted_alert *p);
void handleTorrentDeleteFailedAlert(libtorrent::torrent_delete_failed_alert *p); void handleTorrentDeleteFailedAlert(const libtorrent::torrent_delete_failed_alert *p);
void handlePortmapWarningAlert(libtorrent::portmap_error_alert *p); void handlePortmapWarningAlert(const libtorrent::portmap_error_alert *p);
void handlePortmapAlert(libtorrent::portmap_alert *p); void handlePortmapAlert(const libtorrent::portmap_alert *p);
void handlePeerBlockedAlert(libtorrent::peer_blocked_alert *p); void handlePeerBlockedAlert(const libtorrent::peer_blocked_alert *p);
void handlePeerBanAlert(libtorrent::peer_ban_alert *p); void handlePeerBanAlert(const libtorrent::peer_ban_alert *p);
void handleUrlSeedAlert(libtorrent::url_seed_alert *p); void handleUrlSeedAlert(const libtorrent::url_seed_alert *p);
void handleListenSucceededAlert(libtorrent::listen_succeeded_alert *p); void handleListenSucceededAlert(const libtorrent::listen_succeeded_alert *p);
void handleListenFailedAlert(libtorrent::listen_failed_alert *p); void handleListenFailedAlert(const libtorrent::listen_failed_alert *p);
void handleExternalIPAlert(libtorrent::external_ip_alert *p); void handleExternalIPAlert(const libtorrent::external_ip_alert *p);
void handleSessionStatsAlert(libtorrent::session_stats_alert *p); void handleSessionStatsAlert(const libtorrent::session_stats_alert *p);
void createTorrentHandle(const libtorrent::torrent_handle &nativeHandle); void createTorrentHandle(const libtorrent::torrent_handle &nativeHandle);

View File

@ -57,7 +57,7 @@ namespace BitTorrent
void create(const TorrentCreatorParams &params); void create(const TorrentCreatorParams &params);
static int calculateTotalPieces(const QString &inputPath, const int pieceSize, const bool isAlignmentOptimized); static int calculateTotalPieces(const QString &inputPath, int pieceSize, bool isAlignmentOptimized);
protected: protected:
void run(); void run();

View File

@ -299,7 +299,7 @@ QString TorrentHandle::rootPath(bool actual) const
if ((filesCount() > 1) && !hasRootFolder()) if ((filesCount() > 1) && !hasRootFolder())
return QString(); return QString();
QString firstFilePath = filePath(0); const QString firstFilePath = filePath(0);
const int slashIndex = firstFilePath.indexOf('/'); const int slashIndex = firstFilePath.indexOf('/');
if (slashIndex >= 0) if (slashIndex >= 0)
return QDir(savePath(actual)).absoluteFilePath(firstFilePath.left(slashIndex)); return QDir(savePath(actual)).absoluteFilePath(firstFilePath.left(slashIndex));
@ -462,10 +462,10 @@ bool TorrentHandle::removeUrlSeed(const QUrl &urlSeed)
bool TorrentHandle::connectPeer(const PeerAddress &peerAddress) bool TorrentHandle::connectPeer(const PeerAddress &peerAddress)
{ {
libt::error_code ec; libt::error_code ec;
libt::address addr = libt::address::from_string(peerAddress.ip.toString().toStdString(), ec); const libt::address addr = libt::address::from_string(peerAddress.ip.toString().toStdString(), ec);
if (ec) return false; if (ec) return false;
boost::asio::ip::tcp::endpoint ep(addr, peerAddress.port); const boost::asio::ip::tcp::endpoint ep(addr, peerAddress.port);
m_nativeHandle.connect_peer(ep); m_nativeHandle.connect_peer(ep);
return true; return true;
} }
@ -504,7 +504,7 @@ qreal TorrentHandle::progress() const
if (m_nativeStatus.total_wanted_done == m_nativeStatus.total_wanted) if (m_nativeStatus.total_wanted_done == m_nativeStatus.total_wanted)
return 1.; return 1.;
qreal progress = static_cast<qreal>(m_nativeStatus.total_wanted_done) / m_nativeStatus.total_wanted; const qreal progress = static_cast<qreal>(m_nativeStatus.total_wanted_done) / m_nativeStatus.total_wanted;
Q_ASSERT((progress >= 0.f) && (progress <= 1.f)); Q_ASSERT((progress >= 0.f) && (progress <= 1.f));
return progress; return progress;
} }
@ -608,7 +608,7 @@ QStringList TorrentHandle::absoluteFilePaths() const
{ {
if (!hasMetadata()) return QStringList(); if (!hasMetadata()) return QStringList();
QDir saveDir(savePath(true)); const QDir saveDir(savePath(true));
QStringList res; QStringList res;
for (int i = 0; i < filesCount(); ++i) for (int i = 0; i < filesCount(); ++i)
res << Utils::Fs::expandPathAbs(saveDir.absoluteFilePath(filePath(i))); res << Utils::Fs::expandPathAbs(saveDir.absoluteFilePath(filePath(i)));
@ -619,12 +619,11 @@ QStringList TorrentHandle::absoluteFilePathsUnwanted() const
{ {
if (!hasMetadata()) return QStringList(); if (!hasMetadata()) return QStringList();
QDir saveDir(savePath(true)); const QDir saveDir(savePath(true));
QStringList res; QStringList res;
std::vector<int> fp; const std::vector<int> fp = m_nativeHandle.file_priorities();
fp = m_nativeHandle.file_priorities();
int count = static_cast<int>(fp.size()); const int count = static_cast<int>(fp.size());
for (int i = 0; i < count; ++i) { for (int i = 0; i < count; ++i) {
if (fp[i] == 0) { if (fp[i] == 0) {
const QString path = Utils::Fs::expandPathAbs(saveDir.absoluteFilePath(filePath(i))); const QString path = Utils::Fs::expandPathAbs(saveDir.absoluteFilePath(filePath(i)));
@ -638,8 +637,7 @@ QStringList TorrentHandle::absoluteFilePathsUnwanted() const
QVector<int> TorrentHandle::filePriorities() const QVector<int> TorrentHandle::filePriorities() const
{ {
std::vector<int> fp; const std::vector<int> fp = m_nativeHandle.file_priorities();
fp = m_nativeHandle.file_priorities();
return QVector<int>::fromStdVector(fp); return QVector<int>::fromStdVector(fp);
} }
@ -891,8 +889,8 @@ qulonglong TorrentHandle::eta() const
const SpeedSampleAvg speedAverage = m_speedMonitor.average(); const SpeedSampleAvg speedAverage = m_speedMonitor.average();
if (isSeed()) { if (isSeed()) {
qreal maxRatioValue = maxRatio(); const qreal maxRatioValue = maxRatio();
int maxSeedingTimeValue = maxSeedingTime(); const int maxSeedingTimeValue = maxSeedingTime();
if ((maxRatioValue < 0) && (maxSeedingTimeValue < 0)) return MAX_ETA; if ((maxRatioValue < 0) && (maxSeedingTimeValue < 0)) return MAX_ETA;
qlonglong ratioEta = MAX_ETA; qlonglong ratioEta = MAX_ETA;
@ -963,7 +961,7 @@ int TorrentHandle::totalSeedsCount() const
int TorrentHandle::totalPeersCount() const int TorrentHandle::totalPeersCount() const
{ {
int peers = m_nativeStatus.num_complete + m_nativeStatus.num_incomplete; const int peers = m_nativeStatus.num_complete + m_nativeStatus.num_incomplete;
return (peers > 0) ? peers : m_nativeStatus.list_peers; return (peers > 0) ? peers : m_nativeStatus.list_peers;
} }
@ -1101,14 +1099,14 @@ int TorrentHandle::maxSeedingTime() const
qreal TorrentHandle::realRatio() const qreal TorrentHandle::realRatio() const
{ {
boost::int64_t upload = m_nativeStatus.all_time_upload; const boost::int64_t upload = m_nativeStatus.all_time_upload;
// special case for a seeder who lost its stats, also assume nobody will import a 99% done torrent // special case for a seeder who lost its stats, also assume nobody will import a 99% done torrent
boost::int64_t download = (m_nativeStatus.all_time_download < m_nativeStatus.total_done * 0.01) ? m_nativeStatus.total_done : m_nativeStatus.all_time_download; const boost::int64_t download = (m_nativeStatus.all_time_download < m_nativeStatus.total_done * 0.01) ? m_nativeStatus.total_done : m_nativeStatus.all_time_download;
if (download == 0) if (download == 0)
return (upload == 0) ? 0.0 : MAX_RATIO; return (upload == 0) ? 0.0 : MAX_RATIO;
qreal ratio = upload / static_cast<qreal>(download); const qreal ratio = upload / static_cast<qreal>(download);
Q_ASSERT(ratio >= 0.0); Q_ASSERT(ratio >= 0.0);
return (ratio > MAX_RATIO) ? MAX_RATIO : ratio; return (ratio > MAX_RATIO) ? MAX_RATIO : ratio;
} }
@ -1162,7 +1160,7 @@ bool TorrentHandle::setCategory(const QString &category)
if (!category.isEmpty() && !m_session->categories().contains(category)) if (!category.isEmpty() && !m_session->categories().contains(category))
return false; return false;
QString oldCategory = m_category; const QString oldCategory = m_category;
m_category = category; m_category = category;
m_session->handleTorrentCategoryChanged(this, oldCategory); m_session->handleTorrentCategoryChanged(this, oldCategory);
@ -1228,7 +1226,7 @@ void TorrentHandle::forceRecheck()
} }
} }
void TorrentHandle::setSequentialDownload(bool b) void TorrentHandle::setSequentialDownload(const bool b)
{ {
if (b != isSequentialDownload()) { if (b != isSequentialDownload()) {
m_nativeHandle.set_sequential_download(b); m_nativeHandle.set_sequential_download(b);
@ -1352,8 +1350,8 @@ bool TorrentHandle::saveTorrentFile(const QString &path)
{ {
if (!m_torrentInfo.isValid()) return false; if (!m_torrentInfo.isValid()) return false;
libt::create_torrent torrentCreator = libt::create_torrent(*(m_torrentInfo.nativeInfo()), true); const libt::create_torrent torrentCreator = libt::create_torrent(*(m_torrentInfo.nativeInfo()), true);
libt::entry torrentEntry = torrentCreator.generate(); const libt::entry torrentEntry = torrentCreator.generate();
QVector<char> out; QVector<char> out;
libt::bencode(std::back_inserter(out), torrentEntry); libt::bencode(std::back_inserter(out), torrentEntry);
@ -1434,7 +1432,7 @@ void TorrentHandle::handleStorageMovedFailedAlert(const libtorrent::storage_move
void TorrentHandle::handleTrackerReplyAlert(const libtorrent::tracker_reply_alert *p) void TorrentHandle::handleTrackerReplyAlert(const libtorrent::tracker_reply_alert *p)
{ {
QString trackerUrl(p->tracker_url()); const QString trackerUrl(p->tracker_url());
qDebug("Received a tracker reply from %s (Num_peers = %d)", qUtf8Printable(trackerUrl), p->num_peers); qDebug("Received a tracker reply from %s (Num_peers = %d)", qUtf8Printable(trackerUrl), p->num_peers);
// Connection was successful now. Remove possible old errors // Connection was successful now. Remove possible old errors
m_trackerInfos[trackerUrl].lastMessage.clear(); // Reset error/warning message m_trackerInfos[trackerUrl].lastMessage.clear(); // Reset error/warning message
@ -1563,7 +1561,7 @@ void TorrentHandle::handleSaveResumeDataAlert(const libtorrent::save_resume_data
resumeData["qBt-sequential"] = isSequentialDownload(); resumeData["qBt-sequential"] = isSequentialDownload();
} }
else { else {
auto savePath = resumeData.find_key("save_path")->string(); const auto savePath = resumeData.find_key("save_path")->string();
resumeData["save_path"] = Profile::instance().toPortablePath(QString::fromStdString(savePath)).toStdString(); resumeData["save_path"] = Profile::instance().toPortablePath(QString::fromStdString(savePath)).toStdString();
} }
resumeData["qBt-savePath"] = m_useAutoTMM ? "" : Profile::instance().toPortablePath(m_savePath).toStdString(); resumeData["qBt-savePath"] = m_useAutoTMM ? "" : Profile::instance().toPortablePath(m_savePath).toStdString();
@ -1605,7 +1603,7 @@ void TorrentHandle::handleFastResumeRejectedAlert(const libtorrent::fastresume_r
void TorrentHandle::handleFileRenamedAlert(const libtorrent::file_renamed_alert *p) void TorrentHandle::handleFileRenamedAlert(const libtorrent::file_renamed_alert *p)
{ {
QString newName = Utils::Fs::fromNativePath(p->new_name()); const QString newName = Utils::Fs::fromNativePath(p->new_name());
// TODO: Check this! // TODO: Check this!
if (filesCount() > 1) { if (filesCount() > 1) {
@ -1615,7 +1613,7 @@ void TorrentHandle::handleFileRenamedAlert(const libtorrent::file_renamed_alert
QString oldPath = oldPathParts.join('/'); QString oldPath = oldPathParts.join('/');
QStringList newPathParts = newName.split('/'); QStringList newPathParts = newName.split('/');
newPathParts.removeLast(); newPathParts.removeLast();
QString newPath = newPathParts.join('/'); const QString newPath = newPathParts.join('/');
if (!newPathParts.isEmpty() && (oldPath != newPath)) { if (!newPathParts.isEmpty() && (oldPath != newPath)) {
qDebug("oldPath(%s) != newPath(%s)", qUtf8Printable(oldPath), qUtf8Printable(newPath)); qDebug("oldPath(%s) != newPath(%s)", qUtf8Printable(oldPath), qUtf8Printable(newPath));
oldPath = QString("%1/%2").arg(savePath(true), oldPath); oldPath = QString("%1/%2").arg(savePath(true), oldPath);
@ -1663,7 +1661,7 @@ void TorrentHandle::handleFileCompletedAlert(const libtorrent::file_completed_al
void TorrentHandle::handleStatsAlert(const libtorrent::stats_alert *p) void TorrentHandle::handleStatsAlert(const libtorrent::stats_alert *p)
{ {
Q_ASSERT(p->interval >= 1000); Q_ASSERT(p->interval >= 1000);
SpeedSample transferred(p->transferred[libt::stats_alert::download_payload] * 1000LL / p->interval, const SpeedSample transferred(p->transferred[libt::stats_alert::download_payload] * 1000LL / p->interval,
p->transferred[libt::stats_alert::upload_payload] * 1000LL / p->interval); p->transferred[libt::stats_alert::upload_payload] * 1000LL / p->interval);
m_speedMonitor.addSample(transferred); m_speedMonitor.addSample(transferred);
} }
@ -1714,59 +1712,59 @@ void TorrentHandle::handleAppendExtensionToggled()
manageIncompleteFiles(); manageIncompleteFiles();
} }
void TorrentHandle::handleAlert(libtorrent::alert *a) void TorrentHandle::handleAlert(const libtorrent::alert *a)
{ {
switch (a->type()) { switch (a->type()) {
case libt::stats_alert::alert_type: case libt::stats_alert::alert_type:
handleStatsAlert(static_cast<libt::stats_alert*>(a)); handleStatsAlert(static_cast<const libt::stats_alert*>(a));
break; break;
case libt::file_renamed_alert::alert_type: case libt::file_renamed_alert::alert_type:
handleFileRenamedAlert(static_cast<libt::file_renamed_alert*>(a)); handleFileRenamedAlert(static_cast<const libt::file_renamed_alert*>(a));
break; break;
case libt::file_rename_failed_alert::alert_type: case libt::file_rename_failed_alert::alert_type:
handleFileRenameFailedAlert(static_cast<libt::file_rename_failed_alert*>(a)); handleFileRenameFailedAlert(static_cast<const libt::file_rename_failed_alert*>(a));
break; break;
case libt::file_completed_alert::alert_type: case libt::file_completed_alert::alert_type:
handleFileCompletedAlert(static_cast<libt::file_completed_alert*>(a)); handleFileCompletedAlert(static_cast<const libt::file_completed_alert*>(a));
break; break;
case libt::torrent_finished_alert::alert_type: case libt::torrent_finished_alert::alert_type:
handleTorrentFinishedAlert(static_cast<libt::torrent_finished_alert*>(a)); handleTorrentFinishedAlert(static_cast<const libt::torrent_finished_alert*>(a));
break; break;
case libt::save_resume_data_alert::alert_type: case libt::save_resume_data_alert::alert_type:
handleSaveResumeDataAlert(static_cast<libt::save_resume_data_alert*>(a)); handleSaveResumeDataAlert(static_cast<const libt::save_resume_data_alert*>(a));
break; break;
case libt::save_resume_data_failed_alert::alert_type: case libt::save_resume_data_failed_alert::alert_type:
handleSaveResumeDataFailedAlert(static_cast<libt::save_resume_data_failed_alert*>(a)); handleSaveResumeDataFailedAlert(static_cast<const libt::save_resume_data_failed_alert*>(a));
break; break;
case libt::storage_moved_alert::alert_type: case libt::storage_moved_alert::alert_type:
handleStorageMovedAlert(static_cast<libt::storage_moved_alert*>(a)); handleStorageMovedAlert(static_cast<const libt::storage_moved_alert*>(a));
break; break;
case libt::storage_moved_failed_alert::alert_type: case libt::storage_moved_failed_alert::alert_type:
handleStorageMovedFailedAlert(static_cast<libt::storage_moved_failed_alert*>(a)); handleStorageMovedFailedAlert(static_cast<const libt::storage_moved_failed_alert*>(a));
break; break;
case libt::torrent_paused_alert::alert_type: case libt::torrent_paused_alert::alert_type:
handleTorrentPausedAlert(static_cast<libt::torrent_paused_alert*>(a)); handleTorrentPausedAlert(static_cast<const libt::torrent_paused_alert*>(a));
break; break;
case libt::torrent_resumed_alert::alert_type: case libt::torrent_resumed_alert::alert_type:
handleTorrentResumedAlert(static_cast<libt::torrent_resumed_alert*>(a)); handleTorrentResumedAlert(static_cast<const libt::torrent_resumed_alert*>(a));
break; break;
case libt::tracker_error_alert::alert_type: case libt::tracker_error_alert::alert_type:
handleTrackerErrorAlert(static_cast<libt::tracker_error_alert*>(a)); handleTrackerErrorAlert(static_cast<const libt::tracker_error_alert*>(a));
break; break;
case libt::tracker_reply_alert::alert_type: case libt::tracker_reply_alert::alert_type:
handleTrackerReplyAlert(static_cast<libt::tracker_reply_alert*>(a)); handleTrackerReplyAlert(static_cast<const libt::tracker_reply_alert*>(a));
break; break;
case libt::tracker_warning_alert::alert_type: case libt::tracker_warning_alert::alert_type:
handleTrackerWarningAlert(static_cast<libt::tracker_warning_alert*>(a)); handleTrackerWarningAlert(static_cast<const libt::tracker_warning_alert*>(a));
break; break;
case libt::metadata_received_alert::alert_type: case libt::metadata_received_alert::alert_type:
handleMetadataReceivedAlert(static_cast<libt::metadata_received_alert*>(a)); handleMetadataReceivedAlert(static_cast<const libt::metadata_received_alert*>(a));
break; break;
case libt::fastresume_rejected_alert::alert_type: case libt::fastresume_rejected_alert::alert_type:
handleFastResumeRejectedAlert(static_cast<libt::fastresume_rejected_alert*>(a)); handleFastResumeRejectedAlert(static_cast<const libt::fastresume_rejected_alert*>(a));
break; break;
case libt::torrent_checked_alert::alert_type: case libt::torrent_checked_alert::alert_type:
handleTorrentCheckedAlert(static_cast<libt::torrent_checked_alert*>(a)); handleTorrentCheckedAlert(static_cast<const libt::torrent_checked_alert*>(a));
break; break;
} }
} }
@ -1774,7 +1772,7 @@ void TorrentHandle::handleAlert(libtorrent::alert *a)
void TorrentHandle::manageIncompleteFiles() void TorrentHandle::manageIncompleteFiles()
{ {
const bool isAppendExtensionEnabled = m_session->isAppendExtensionEnabled(); const bool isAppendExtensionEnabled = m_session->isAppendExtensionEnabled();
QVector<qreal> fp = filesProgress(); const QVector<qreal> fp = filesProgress();
if (fp.size() != filesCount()) { if (fp.size() != filesCount()) {
qDebug() << "skip manageIncompleteFiles because of invalid torrent meta-data or empty file-progress"; qDebug() << "skip manageIncompleteFiles because of invalid torrent meta-data or empty file-progress";
return; return;
@ -1893,17 +1891,17 @@ void TorrentHandle::setSeedingTimeLimit(int limit)
} }
} }
void TorrentHandle::setUploadLimit(int limit) void TorrentHandle::setUploadLimit(const int limit)
{ {
m_nativeHandle.set_upload_limit(limit); m_nativeHandle.set_upload_limit(limit);
} }
void TorrentHandle::setDownloadLimit(int limit) void TorrentHandle::setDownloadLimit(const int limit)
{ {
m_nativeHandle.set_download_limit(limit); m_nativeHandle.set_download_limit(limit);
} }
void TorrentHandle::setSuperSeeding(bool enable) void TorrentHandle::setSuperSeeding(const bool enable)
{ {
m_nativeHandle.super_seeding(enable); m_nativeHandle.super_seeding(enable);
} }
@ -1928,8 +1926,8 @@ void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
// 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(); const QVector<qreal> progress = filesProgress();
QVector<int> oldPriorities = filePriorities(); const QVector<int> oldPriorities = filePriorities();
for (int i = 0; i < oldPriorities.size(); ++i) { for (int i = 0; i < oldPriorities.size(); ++i) {
if ((oldPriorities[i] == 0) && (priorities[i] > 0) && (progress[i] < 1.0)) { if ((oldPriorities[i] == 0) && (priorities[i] > 0) && (progress[i] < 1.0)) {
m_hasSeedStatus = false; m_hasSeedStatus = false;
@ -1941,24 +1939,24 @@ void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
m_nativeHandle.prioritize_files(priorities.toStdVector()); m_nativeHandle.prioritize_files(priorities.toStdVector());
qDebug() << Q_FUNC_INFO << "Moving unwanted files to .unwanted folder and conversely..."; qDebug() << Q_FUNC_INFO << "Moving unwanted files to .unwanted folder and conversely...";
QString spath = savePath(true); const QString spath = savePath(true);
for (int i = 0; i < priorities.size(); ++i) { for (int i = 0; i < priorities.size(); ++i) {
QString filepath = filePath(i); const QString filepath = filePath(i);
// Move unwanted files to a .unwanted subfolder // Move unwanted files to a .unwanted subfolder
if (priorities[i] == 0) { if (priorities[i] == 0) {
QString oldAbsPath = QDir(spath).absoluteFilePath(filepath); const QString oldAbsPath = QDir(spath).absoluteFilePath(filepath);
QString parentAbsPath = Utils::Fs::branchPath(oldAbsPath); const QString parentAbsPath = Utils::Fs::branchPath(oldAbsPath);
// Make sure the file does not already exists // Make sure the file does not already exists
if (QDir(parentAbsPath).dirName() != ".unwanted") { if (QDir(parentAbsPath).dirName() != ".unwanted") {
QString unwantedAbsPath = parentAbsPath + "/.unwanted"; const QString unwantedAbsPath = parentAbsPath + "/.unwanted";
QString newAbsPath = unwantedAbsPath + '/' + Utils::Fs::fileName(filepath); const QString newAbsPath = unwantedAbsPath + '/' + Utils::Fs::fileName(filepath);
qDebug() << "Unwanted path is" << unwantedAbsPath; qDebug() << "Unwanted path is" << unwantedAbsPath;
if (QFile::exists(newAbsPath)) { if (QFile::exists(newAbsPath)) {
qWarning() << "File" << newAbsPath << "already exists at destination."; qWarning() << "File" << newAbsPath << "already exists at destination.";
continue; continue;
} }
bool created = QDir().mkpath(unwantedAbsPath); const bool created = QDir().mkpath(unwantedAbsPath);
qDebug() << "unwanted folder was created:" << created; qDebug() << "unwanted folder was created:" << created;
#ifdef Q_OS_WIN #ifdef Q_OS_WIN
if (created) { if (created) {
@ -1979,10 +1977,10 @@ void TorrentHandle::prioritizeFiles(const QVector<int> &priorities)
// Move wanted files back to their original folder // Move wanted files back to their original folder
if (priorities[i] > 0) { if (priorities[i] > 0) {
QString parentRelPath = Utils::Fs::branchPath(filepath); const QString parentRelPath = Utils::Fs::branchPath(filepath);
if (QDir(parentRelPath).dirName() == ".unwanted") { if (QDir(parentRelPath).dirName() == ".unwanted") {
QString oldName = Utils::Fs::fileName(filepath); const QString oldName = Utils::Fs::fileName(filepath);
QString newRelPath = Utils::Fs::branchPath(parentRelPath); const QString newRelPath = Utils::Fs::branchPath(parentRelPath);
if (newRelPath.isEmpty()) if (newRelPath.isEmpty())
renameFile(i, oldName); renameFile(i, oldName);
else else

View File

@ -358,7 +358,7 @@ namespace BitTorrent
// Session interface // Session interface
libtorrent::torrent_handle nativeHandle() const; libtorrent::torrent_handle nativeHandle() const;
void handleAlert(libtorrent::alert *a); void handleAlert(const libtorrent::alert *a);
void handleStateUpdate(const libtorrent::torrent_status &nativeStatus); void handleStateUpdate(const libtorrent::torrent_status &nativeStatus);
void handleTempPathChanged(); void handleTempPathChanged();
void handleCategorySavePathChanged(); void handleCategorySavePathChanged();

View File

@ -146,7 +146,7 @@ QString TorrentInfo::name() const
QDateTime TorrentInfo::creationDate() const QDateTime TorrentInfo::creationDate() const
{ {
if (!isValid()) return QDateTime(); if (!isValid()) return QDateTime();
boost::optional<time_t> t = m_nativeInfo->creation_date(); const boost::optional<time_t> t = m_nativeInfo->creation_date();
return t ? QDateTime::fromTime_t(*t) : QDateTime(); return t ? QDateTime::fromTime_t(*t) : QDateTime();
} }
@ -186,7 +186,7 @@ int TorrentInfo::pieceLength() const
return m_nativeInfo->piece_length(); return m_nativeInfo->piece_length();
} }
int TorrentInfo::pieceLength(int index) const int TorrentInfo::pieceLength(const int index) const
{ {
if (!isValid()) return -1; if (!isValid()) return -1;
return m_nativeInfo->piece_size(index); return m_nativeInfo->piece_size(index);
@ -198,7 +198,7 @@ int TorrentInfo::piecesCount() const
return m_nativeInfo->num_pieces(); return m_nativeInfo->num_pieces();
} }
QString TorrentInfo::filePath(int index) const QString TorrentInfo::filePath(const int index) const
{ {
if (!isValid()) return QString(); if (!isValid()) return QString();
return Utils::Fs::fromNativePath(QString::fromStdString(m_nativeInfo->files().file_path(index))); return Utils::Fs::fromNativePath(QString::fromStdString(m_nativeInfo->files().file_path(index)));
@ -213,24 +213,24 @@ QStringList TorrentInfo::filePaths() const
return list; return list;
} }
QString TorrentInfo::fileName(int index) const QString TorrentInfo::fileName(const int index) const
{ {
return Utils::Fs::fileName(filePath(index)); return Utils::Fs::fileName(filePath(index));
} }
QString TorrentInfo::origFilePath(int index) const QString TorrentInfo::origFilePath(const int index) const
{ {
if (!isValid()) return QString(); if (!isValid()) return QString();
return Utils::Fs::fromNativePath(QString::fromStdString(m_nativeInfo->orig_files().file_path(index))); return Utils::Fs::fromNativePath(QString::fromStdString(m_nativeInfo->orig_files().file_path(index)));
} }
qlonglong TorrentInfo::fileSize(int index) const qlonglong TorrentInfo::fileSize(const int index) const
{ {
if (!isValid()) return -1; if (!isValid()) return -1;
return m_nativeInfo->files().file_size(index); return m_nativeInfo->files().file_size(index);
} }
qlonglong TorrentInfo::fileOffset(int index) const qlonglong TorrentInfo::fileOffset(const int index) const
{ {
if (!isValid()) return -1; if (!isValid()) return -1;
return m_nativeInfo->files().file_offset(index); return m_nativeInfo->files().file_offset(index);
@ -265,10 +265,10 @@ QByteArray TorrentInfo::metadata() const
return QByteArray(m_nativeInfo->metadata().get(), m_nativeInfo->metadata_size()); return QByteArray(m_nativeInfo->metadata().get(), m_nativeInfo->metadata_size());
} }
QStringList TorrentInfo::filesForPiece(int pieceIndex) const QStringList TorrentInfo::filesForPiece(const int pieceIndex) const
{ {
// no checks here because fileIndicesForPiece() will return an empty list // no checks here because fileIndicesForPiece() will return an empty list
QVector<int> fileIndices = fileIndicesForPiece(pieceIndex); const QVector<int> fileIndices = fileIndicesForPiece(pieceIndex);
QStringList res; QStringList res;
res.reserve(fileIndices.size()); res.reserve(fileIndices.size());
@ -278,12 +278,12 @@ QStringList TorrentInfo::filesForPiece(int pieceIndex) const
return res; return res;
} }
QVector<int> TorrentInfo::fileIndicesForPiece(int pieceIndex) const QVector<int> TorrentInfo::fileIndicesForPiece(const int pieceIndex) const
{ {
if (!isValid() || (pieceIndex < 0) || (pieceIndex >= piecesCount())) if (!isValid() || (pieceIndex < 0) || (pieceIndex >= piecesCount()))
return QVector<int>(); return QVector<int>();
std::vector<libt::file_slice> files( const std::vector<libt::file_slice> files(
nativeInfo()->map_block(pieceIndex, 0, nativeInfo()->piece_size(pieceIndex))); nativeInfo()->map_block(pieceIndex, 0, nativeInfo()->piece_size(pieceIndex)));
QVector<int> res; QVector<int> res;
res.reserve(int(files.size())); res.reserve(int(files.size()));
@ -313,7 +313,7 @@ TorrentInfo::PieceRange TorrentInfo::filePieces(const QString &file) const
if (!isValid()) // if we do not check here the debug message will be printed, which would be not correct if (!isValid()) // if we do not check here the debug message will be printed, which would be not correct
return {}; return {};
int index = fileIndex(file); const int index = fileIndex(file);
if (index == -1) { if (index == -1) {
qDebug() << "Filename" << file << "was not found in torrent" << name(); qDebug() << "Filename" << file << "was not found in torrent" << name();
return {}; return {};
@ -321,7 +321,7 @@ TorrentInfo::PieceRange TorrentInfo::filePieces(const QString &file) const
return filePieces(index); return filePieces(index);
} }
TorrentInfo::PieceRange TorrentInfo::filePieces(int fileIndex) const TorrentInfo::PieceRange TorrentInfo::filePieces(const int fileIndex) const
{ {
if (!isValid()) if (!isValid())
return {}; return {};
@ -387,7 +387,7 @@ void TorrentInfo::stripRootFolder()
libtorrent::file_storage files = m_nativeInfo->files(); libtorrent::file_storage files = m_nativeInfo->files();
// Solution for case of renamed root folder // Solution for case of renamed root folder
std::string testName = filePath(0).split('/').value(0).toStdString(); const std::string testName = filePath(0).split('/').value(0).toStdString();
if (files.name() != testName) { if (files.name() != testName) {
files.set_name(testName); files.set_name(testName);
for (int i = 0; i < files.num_files(); ++i) for (int i = 0; i < files.num_files(); ++i)

View File

@ -63,7 +63,7 @@ QString Peer::uid() const
return ip.toString() + ':' + QString::number(port); return ip.toString() + ':' + QString::number(port);
} }
libtorrent::entry Peer::toEntry(bool noPeerId) const libtorrent::entry Peer::toEntry(const bool noPeerId) const
{ {
libtorrent::entry::dictionary_type peerMap; libtorrent::entry::dictionary_type peerMap;
if (!noPeerId) if (!noPeerId)

View File

@ -533,7 +533,7 @@ void SearchPluginManager::parseVersionInfo(const QByteArray &info)
} }
} }
bool SearchPluginManager::isUpdateNeeded(QString pluginName, PluginVersion newVersion) const bool SearchPluginManager::isUpdateNeeded(const QString &pluginName, PluginVersion newVersion) const
{ {
PluginInfo *plugin = pluginInfo(pluginName); PluginInfo *plugin = pluginInfo(pluginName);
if (!plugin) return true; if (!plugin) return true;

View File

@ -102,7 +102,7 @@ private:
void updateNova(); void updateNova();
void parseVersionInfo(const QByteArray &info); void parseVersionInfo(const QByteArray &info);
void installPlugin_impl(const QString &name, const QString &path); void installPlugin_impl(const QString &name, const QString &path);
bool isUpdateNeeded(QString pluginName, PluginVersion newVersion) const; bool isUpdateNeeded(const QString &pluginName, PluginVersion newVersion) const;
void versionInfoDownloaded(const QString &url, const QByteArray &data); void versionInfoDownloaded(const QString &url, const QByteArray &data);
void versionInfoDownloadFailed(const QString &url, const QString &reason); void versionInfoDownloadFailed(const QString &url, const QString &reason);

View File

@ -850,7 +850,7 @@ void MainWindow::finishedTorrent(BitTorrent::TorrentHandle *const torrent) const
} }
// Notification when disk is full // Notification when disk is full
void MainWindow::fullDiskError(BitTorrent::TorrentHandle *const torrent, QString msg) const void MainWindow::fullDiskError(BitTorrent::TorrentHandle *const torrent, const QString &msg) const
{ {
showNotificationBaloon(tr("I/O Error", "i.e: Input/Output Error") showNotificationBaloon(tr("I/O Error", "i.e: Input/Output Error")
, tr("An I/O error occurred for torrent '%1'.\n Reason: %2" , tr("An I/O error occurred for torrent '%1'.\n Reason: %2"
@ -964,7 +964,7 @@ void MainWindow::askRecursiveTorrentDownloadConfirmation(BitTorrent::TorrentHand
confirmBox->show(); confirmBox->show();
} }
void MainWindow::handleDownloadFromUrlFailure(QString url, QString reason) const void MainWindow::handleDownloadFromUrlFailure(const QString &url, const QString &reason) const
{ {
// Display a message box // Display a message box
showNotificationBaloon(tr("URL download error") showNotificationBaloon(tr("URL download error")
@ -1062,7 +1062,7 @@ bool MainWindow::unlockUI()
return true; return true;
} }
void MainWindow::notifyOfUpdate(QString) void MainWindow::notifyOfUpdate(const QString &)
{ {
// Show restart message // Show restart message
m_statusBar->showRestartRequired(); m_statusBar->showRestartRequired();
@ -1569,7 +1569,7 @@ void MainWindow::updateGUI()
} }
} }
void MainWindow::showNotificationBaloon(QString title, QString msg) const void MainWindow::showNotificationBaloon(const QString &title, const QString &msg) const
{ {
if (!isNotificationsEnabled()) return; if (!isNotificationsEnabled()) return;
#if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) && defined(QT_DBUS_LIB) #if (defined(Q_OS_UNIX) && !defined(Q_OS_MAC)) && defined(QT_DBUS_LIB)

View File

@ -99,20 +99,20 @@ public:
void activate(); void activate();
void cleanup(); void cleanup();
void showNotificationBaloon(QString title, QString msg) const; void showNotificationBaloon(const QString &title, const QString &msg) const;
private slots: private slots:
void showFilterContextMenu(const QPoint &); void showFilterContextMenu(const QPoint &);
void balloonClicked(); void balloonClicked();
void writeSettings(); void writeSettings();
void readSettings(); void readSettings();
void fullDiskError(BitTorrent::TorrentHandle *const torrent, QString msg) const; void fullDiskError(BitTorrent::TorrentHandle *const torrent, const QString &msg) const;
void handleDownloadFromUrlFailure(QString, QString) const; void handleDownloadFromUrlFailure(const QString &, const QString &) const;
void tabChanged(int newTab); void tabChanged(int newTab);
bool defineUILockPassword(); bool defineUILockPassword();
void clearUILockPassword(); void clearUILockPassword();
bool unlockUI(); bool unlockUI();
void notifyOfUpdate(QString); void notifyOfUpdate(const QString &);
void showConnectionSettings(); void showConnectionSettings();
void minimizeWindow(); void minimizeWindow();
// Keyboard shortcuts // Keyboard shortcuts

View File

@ -120,9 +120,9 @@ int PropTabBar::currentIndex() const
void PropTabBar::setCurrentIndex(int index) void PropTabBar::setCurrentIndex(int index)
{ {
if (index >= m_btnGroup->buttons().size()) if (index >= m_btnGroup->buttons().size())
index = 0; index = 0;
// If asked to hide or if the currently selected tab is clicked // If asked to hide or if the currently selected tab is clicked
if (index < 0 || m_currentIndex == index) { if ((index < 0) || (m_currentIndex == index)) {
if (m_currentIndex >= 0) { if (m_currentIndex >= 0) {
m_btnGroup->button(m_currentIndex)->setDown(false); m_btnGroup->button(m_currentIndex)->setDown(false);
m_currentIndex = -1; m_currentIndex = -1;

View File

@ -149,7 +149,7 @@ QList<QTreeWidgetItem*> TrackerListWidget::getSelectedTrackerItems() const
return selectedTrackers; return selectedTrackers;
} }
void TrackerListWidget::setRowColor(int row, QColor color) void TrackerListWidget::setRowColor(const int row, const QColor &color)
{ {
const int nbColumns = columnCount(); const int nbColumns = columnCount();
QTreeWidgetItem *item = topLevelItem(row); QTreeWidgetItem *item = topLevelItem(row);

View File

@ -69,7 +69,7 @@ public:
int visibleColumnsCount() const; int visibleColumnsCount() const;
public slots: public slots:
void setRowColor(int row, QColor color); void setRowColor(int row, const QColor &color);
void moveSelectionUp(); void moveSelectionUp();
void moveSelectionDown(); void moveSelectionDown();

View File

@ -228,7 +228,7 @@ void PluginSelectDialog::enableSelection(bool enable)
} }
// Set the color of a row in data model // Set the color of a row in data model
void PluginSelectDialog::setRowColor(int row, QString color) void PluginSelectDialog::setRowColor(const int row, const QString &color)
{ {
QTreeWidgetItem *item = m_ui->pluginsTree->topLevelItem(row); QTreeWidgetItem *item = m_ui->pluginsTree->topLevelItem(row);
for (int i = 0; i < m_ui->pluginsTree->columnCount(); ++i) { for (int i = 0; i < m_ui->pluginsTree->columnCount(); ++i) {
@ -236,7 +236,7 @@ void PluginSelectDialog::setRowColor(int row, QString color)
} }
} }
QList<QTreeWidgetItem*> PluginSelectDialog::findItemsWithUrl(QString url) QList<QTreeWidgetItem*> PluginSelectDialog::findItemsWithUrl(const QString &url)
{ {
QList<QTreeWidgetItem*> res; QList<QTreeWidgetItem*> res;
@ -249,7 +249,7 @@ QList<QTreeWidgetItem*> PluginSelectDialog::findItemsWithUrl(QString url)
return res; return res;
} }
QTreeWidgetItem *PluginSelectDialog::findItemWithID(QString id) QTreeWidgetItem *PluginSelectDialog::findItemWithID(const QString &id)
{ {
for (int i = 0; i < m_ui->pluginsTree->topLevelItemCount(); ++i) { for (int i = 0; i < m_ui->pluginsTree->topLevelItemCount(); ++i) {
QTreeWidgetItem *item = m_ui->pluginsTree->topLevelItem(i); QTreeWidgetItem *item = m_ui->pluginsTree->topLevelItem(i);
@ -268,7 +268,7 @@ void PluginSelectDialog::loadSupportedSearchPlugins()
addNewPlugin(name); addNewPlugin(name);
} }
void PluginSelectDialog::addNewPlugin(QString pluginName) void PluginSelectDialog::addNewPlugin(const QString &pluginName)
{ {
QTreeWidgetItem *item = new QTreeWidgetItem(m_ui->pluginsTree); QTreeWidgetItem *item = new QTreeWidgetItem(m_ui->pluginsTree);
PluginInfo *plugin = m_pluginManager->pluginInfo(pluginName); PluginInfo *plugin = m_pluginManager->pluginInfo(pluginName);

View File

@ -51,8 +51,8 @@ public:
explicit PluginSelectDialog(SearchPluginManager *pluginManager, QWidget *parent = nullptr); explicit PluginSelectDialog(SearchPluginManager *pluginManager, QWidget *parent = nullptr);
~PluginSelectDialog(); ~PluginSelectDialog();
QList<QTreeWidgetItem*> findItemsWithUrl(QString url); QList<QTreeWidgetItem*> findItemsWithUrl(const QString &url);
QTreeWidgetItem *findItemWithID(QString id); QTreeWidgetItem *findItemWithID(const QString &id);
protected: protected:
void dropEvent(QDropEvent *event) override; void dropEvent(QDropEvent *event) override;
@ -64,7 +64,7 @@ private slots:
void on_installButton_clicked(); void on_installButton_clicked();
void on_closeButton_clicked(); void on_closeButton_clicked();
void togglePluginState(QTreeWidgetItem*, int); void togglePluginState(QTreeWidgetItem*, int);
void setRowColor(int row, QString color); void setRowColor(int row, const QString &color);
void displayContextMenu(const QPoint &pos); void displayContextMenu(const QPoint &pos);
void enableSelection(bool enable); void enableSelection(bool enable);
void askForLocalPlugin(); void askForLocalPlugin();
@ -81,7 +81,7 @@ private slots:
private: private:
void loadSupportedSearchPlugins(); void loadSupportedSearchPlugins();
void addNewPlugin(QString pluginName); void addNewPlugin(const QString &pluginName);
void startAsyncOp(); void startAsyncOp();
void finishAsyncOp(); void finishAsyncOp();
void finishPluginUpdate(); void finishPluginUpdate();

View File

@ -280,7 +280,7 @@ void SearchWidget::on_pluginsButton_clicked()
new PluginSelectDialog(SearchPluginManager::instance(), this); new PluginSelectDialog(SearchPluginManager::instance(), this);
} }
void SearchWidget::searchTextEdited(QString) void SearchWidget::searchTextEdited(const QString &)
{ {
// Enable search button // Enable search button
m_ui->searchButton->setText(tr("Search")); m_ui->searchButton->setText(tr("Search"));

View File

@ -74,7 +74,7 @@ private:
void fillCatCombobox(); void fillCatCombobox();
void fillPluginComboBox(); void fillPluginComboBox();
void selectActivePage(); void selectActivePage();
void searchTextEdited(QString); void searchTextEdited(const QString &);
void updateButtons(); void updateButtons();
QString selectedCategory() const; QString selectedCategory() const;

View File

@ -466,8 +466,8 @@ QIcon getErrorIcon()
bool isDarkTheme() bool isDarkTheme()
{ {
QPalette pal = QApplication::palette(); const QPalette pal = QApplication::palette();
// QPalette::Base is used for the background of the Treeview // QPalette::Base is used for the background of the Treeview
QColor color = pal.color(QPalette::Active, QPalette::Base); const QColor color = pal.color(QPalette::Active, QPalette::Base);
return (color.lightness() < 127); return (color.lightness() < 127);
} }

View File

@ -338,7 +338,7 @@ TransferListModel *TransferListWidget::getSourceModel() const
return m_listModel; return m_listModel;
} }
void TransferListWidget::previewFile(QString filePath) void TransferListWidget::previewFile(const QString &filePath)
{ {
Utils::Misc::openPath(filePath); Utils::Misc::openPath(filePath);
} }
@ -854,7 +854,7 @@ void TransferListWidget::renameSelectedTorrent()
} }
} }
void TransferListWidget::setSelectionCategory(QString category) void TransferListWidget::setSelectionCategory(const QString &category)
{ {
for (const QModelIndex &index : asConst(selectionModel()->selectedRows())) for (const QModelIndex &index : asConst(selectionModel()->selectedRows()))
m_listModel->setData(m_listModel->index(mapToSource(index).row(), TransferListModel::TR_CATEGORY), category, Qt::DisplayRole); m_listModel->setData(m_listModel->index(mapToSource(index).row(), TransferListModel::TR_CATEGORY), category, Qt::DisplayRole);
@ -1173,7 +1173,7 @@ void TransferListWidget::currentChanged(const QModelIndex &current, const QModel
emit currentTorrentChanged(torrent); emit currentTorrentChanged(torrent);
} }
void TransferListWidget::applyCategoryFilter(QString category) void TransferListWidget::applyCategoryFilter(const QString &category)
{ {
if (category.isNull()) if (category.isNull())
m_sortFilterModel->disableCategoryFilter(); m_sortFilterModel->disableCategoryFilter();

View File

@ -56,7 +56,7 @@ public:
TransferListModel *getSourceModel() const; TransferListModel *getSourceModel() const;
public slots: public slots:
void setSelectionCategory(QString category); void setSelectionCategory(const QString &category);
void addSelectionTag(const QString &tag); void addSelectionTag(const QString &tag);
void removeSelectionTag(const QString &tag); void removeSelectionTag(const QString &tag);
void clearSelectionTags(); void clearSelectionTags();
@ -90,11 +90,11 @@ public slots:
void displayDLHoSMenu(const QPoint&); void displayDLHoSMenu(const QPoint&);
void applyNameFilter(const QString &name); void applyNameFilter(const QString &name);
void applyStatusFilter(int f); void applyStatusFilter(int f);
void applyCategoryFilter(QString category); void applyCategoryFilter(const QString &category);
void applyTagFilter(const QString &tag); void applyTagFilter(const QString &tag);
void applyTrackerFilterAll(); void applyTrackerFilterAll();
void applyTrackerFilter(const QStringList &hashes); void applyTrackerFilter(const QStringList &hashes);
void previewFile(QString filePath); void previewFile(const QString &filePath);
void renameSelectedTorrent(); void renameSelectedTorrent();
protected: protected:

View File

@ -329,7 +329,7 @@ void AppController::setPreferencesAction()
// Update deleted folders // Update deleted folders
for (auto i = oldScanDirs.cbegin(); i != oldScanDirs.cend(); ++i) { for (auto i = oldScanDirs.cbegin(); i != oldScanDirs.cend(); ++i) {
QString folder = i.key(); const QString folder = i.key();
if (!scanDirs.contains(folder)) { if (!scanDirs.contains(folder)) {
model->removePath(folder); model->removePath(folder);
qDebug("Removed watched folder %s", qUtf8Printable(folder)); qDebug("Removed watched folder %s", qUtf8Printable(folder));