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

Fix ignoring of incorrect version strings in search plugins. Closes #7101.

Printing of Version with all components set to zero was segfaulting due
to underflow in array index. Also add log message for such plugins.
This commit is contained in:
Eugene Shalygin 2017-08-20 20:21:59 +02:00
parent 1e677c6728
commit ef1597e45b
2 changed files with 11 additions and 3 deletions

View File

@ -36,6 +36,7 @@
#include "base/utils/fs.h" #include "base/utils/fs.h"
#include "base/utils/misc.h" #include "base/utils/misc.h"
#include "base/logger.h"
#include "base/preferences.h" #include "base/preferences.h"
#include "base/profile.h" #include "base/profile.h"
#include "base/net/downloadmanager.h" #include "base/net/downloadmanager.h"
@ -669,13 +670,20 @@ PluginVersion SearchEngine::getPluginVersion(QString filePath)
if (!plugin.open(QIODevice::ReadOnly | QIODevice::Text)) if (!plugin.open(QIODevice::ReadOnly | QIODevice::Text))
return {}; return {};
const PluginVersion invalidVersion;
PluginVersion version; PluginVersion version;
while (!plugin.atEnd()) { while (!plugin.atEnd()) {
QByteArray line = plugin.readLine(); QByteArray line = plugin.readLine();
if (line.startsWith("#VERSION: ")) { if (line.startsWith("#VERSION: ")) {
line = line.split(' ').last().trimmed(); line = line.split(' ').last().trimmed();
version = PluginVersion::tryParse(line, {}); version = PluginVersion::tryParse(line, invalidVersion);
qDebug() << "plugin" << filePath << "version: " << version; if (version == invalidVersion) {
LogMsg(tr("Search plugin '%1' contains invalid version string ('%2')")
.arg(Utils::Fs::fileName(filePath)).arg(QString::fromUtf8(line)), Log::MsgType::WARNING);
}
else
qDebug() << "plugin" << filePath << "version: " << version;
break; break;
} }
} }

View File

@ -117,7 +117,7 @@ namespace Utils
{ {
// find the last one non-zero component // find the last one non-zero component
std::size_t lastSignificantIndex = N - 1; std::size_t lastSignificantIndex = N - 1;
while (lastSignificantIndex >= 0 && (*this)[lastSignificantIndex] == 0) while (lastSignificantIndex > 0 && (*this)[lastSignificantIndex] == 0)
--lastSignificantIndex; --lastSignificantIndex;
if (lastSignificantIndex + 1 < Mandatory) // lastSignificantIndex >= 0 if (lastSignificantIndex + 1 < Mandatory) // lastSignificantIndex >= 0