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

Merge pull request #14371 from Chocobo1/units

Fix potential out-of-bounds access
This commit is contained in:
Mike Tzou 2021-02-11 13:15:01 +08:00 committed by GitHub
commit 1df2dd9593
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 21 additions and 15 deletions

View File

@ -28,6 +28,8 @@
#include "misc.h" #include "misc.h"
#include <optional>
#ifdef Q_OS_WIN #ifdef Q_OS_WIN
#include <windows.h> #include <windows.h>
#include <powrprof.h> #include <powrprof.h>
@ -80,21 +82,26 @@ namespace
// see http://en.wikipedia.org/wiki/Kilobyte // see http://en.wikipedia.org/wiki/Kilobyte
// value must be given in bytes // value must be given in bytes
// to send numbers instead of strings with suffixes // to send numbers instead of strings with suffixes
bool splitToFriendlyUnit(const qint64 sizeInBytes, qreal &val, Utils::Misc::SizeUnit &unit) struct SplitToFriendlyUnitResult
{ {
if (sizeInBytes < 0) return false; qreal value;
Utils::Misc::SizeUnit unit;
};
std::optional<SplitToFriendlyUnitResult> splitToFriendlyUnit(const qint64 bytes)
{
if (bytes < 0)
return std::nullopt;
int i = 0; int i = 0;
val = static_cast<qreal>(sizeInBytes); auto value = static_cast<qreal>(bytes);
while ((val >= 1024.) && (i <= static_cast<int>(Utils::Misc::SizeUnit::ExbiByte))) while ((value >= 1024) && (i < static_cast<int>(Utils::Misc::SizeUnit::ExbiByte)))
{ {
val /= 1024.; value /= 1024;
++i; ++i;
} }
return {{value, static_cast<Utils::Misc::SizeUnit>(i)}};
unit = static_cast<Utils::Misc::SizeUnit>(i);
return true;
} }
} }
@ -249,15 +256,14 @@ QString Utils::Misc::unitString(const SizeUnit unit, const bool isSpeed)
return ret; return ret;
} }
QString Utils::Misc::friendlyUnit(const qint64 bytesValue, const bool isSpeed) QString Utils::Misc::friendlyUnit(const qint64 bytes, const bool isSpeed)
{ {
SizeUnit unit; const std::optional<SplitToFriendlyUnitResult> result = splitToFriendlyUnit(bytes);
qreal friendlyVal; if (!result)
if (!splitToFriendlyUnit(bytesValue, friendlyVal, unit))
return QCoreApplication::translate("misc", "Unknown", "Unknown (size)"); return QCoreApplication::translate("misc", "Unknown", "Unknown (size)");
return Utils::String::fromDouble(friendlyVal, friendlyUnitPrecision(unit)) return Utils::String::fromDouble(result->value, friendlyUnitPrecision(result->unit))
+ QString::fromUtf8(C_NON_BREAKING_SPACE) + QString::fromUtf8(C_NON_BREAKING_SPACE)
+ unitString(unit, isSpeed); + unitString(result->unit, isSpeed);
} }
int Utils::Misc::friendlyUnitPrecision(const SizeUnit unit) int Utils::Misc::friendlyUnitPrecision(const SizeUnit unit)

View File

@ -73,7 +73,7 @@ namespace Utils::Misc
// return the best user friendly storage unit (B, KiB, MiB, GiB, TiB) // return the best user friendly storage unit (B, KiB, MiB, GiB, TiB)
// value must be given in bytes // value must be given in bytes
QString friendlyUnit(qint64 bytesValue, bool isSpeed = false); QString friendlyUnit(qint64 bytes, bool isSpeed = false);
int friendlyUnitPrecision(SizeUnit unit); int friendlyUnitPrecision(SizeUnit unit);
qint64 sizeInBytes(qreal size, SizeUnit unit); qint64 sizeInBytes(qreal size, SizeUnit unit);