1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-25 22:14:32 +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 <optional>
#ifdef Q_OS_WIN
#include <windows.h>
#include <powrprof.h>
@ -80,21 +82,26 @@ namespace
// see http://en.wikipedia.org/wiki/Kilobyte
// value must be given in bytes
// 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;
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;
}
unit = static_cast<Utils::Misc::SizeUnit>(i);
return true;
return {{value, static_cast<Utils::Misc::SizeUnit>(i)}};
}
}
@ -249,15 +256,14 @@ QString Utils::Misc::unitString(const SizeUnit unit, const bool isSpeed)
return ret;
}
QString Utils::Misc::friendlyUnit(const qint64 bytesValue, const bool isSpeed)
QString Utils::Misc::friendlyUnit(const qint64 bytes, const bool isSpeed)
{
SizeUnit unit;
qreal friendlyVal;
if (!splitToFriendlyUnit(bytesValue, friendlyVal, unit))
const std::optional<SplitToFriendlyUnitResult> result = splitToFriendlyUnit(bytes);
if (!result)
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)
+ unitString(unit, isSpeed);
+ unitString(result->unit, isSpeed);
}
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)
// value must be given in bytes
QString friendlyUnit(qint64 bytesValue, bool isSpeed = false);
QString friendlyUnit(qint64 bytes, bool isSpeed = false);
int friendlyUnitPrecision(SizeUnit unit);
qint64 sizeInBytes(qreal size, SizeUnit unit);