diff options
author | Shauren <shauren.trinity@gmail.com> | 2023-05-13 15:46:27 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2023-05-13 15:46:27 +0200 |
commit | 3260b94dd627b7b0c7114f94bb97d108b005af3e (patch) | |
tree | 980d58d6db4a3d20785f8bca881d36f79d0f5755 /src/common/Utilities/Util.cpp | |
parent | c4d40085964109893c76d301b6f7d99f03838fa0 (diff) |
Core/Misc: Replace string to int conversion functions from Common.h with c++17 std::from_chars based ones Trinity::StringTo
Diffstat (limited to 'src/common/Utilities/Util.cpp')
-rw-r--r-- | src/common/Utilities/Util.cpp | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/src/common/Utilities/Util.cpp b/src/common/Utilities/Util.cpp index fdd49b49855..ac97e724902 100644 --- a/src/common/Utilities/Util.cpp +++ b/src/common/Utilities/Util.cpp @@ -843,15 +843,13 @@ std::string Trinity::Impl::ByteArrayToHexStr(uint8 const* bytes, size_t arrayLen op = -1; } - std::ostringstream ss; + std::string result; + result.reserve(arrayLen * 2); + auto inserter = std::back_inserter(result); for (int32 i = init; i != end; i += op) - { - char buffer[4]; - sprintf(buffer, "%02X", bytes[i]); - ss << buffer; - } + Trinity::StringFormatTo(inserter, "{:02X}", bytes[i]); - return ss.str(); + return result; } void Trinity::Impl::HexStrToByteArray(std::string_view str, uint8* out, size_t outlen, bool reverse /*= false*/) @@ -871,10 +869,7 @@ void Trinity::Impl::HexStrToByteArray(std::string_view str, uint8* out, size_t o uint32 j = 0; for (int32 i = init; i != end; i += 2 * op) - { - char buffer[3] = { str[i], str[i + 1], '\0' }; - out[j++] = uint8(strtoul(buffer, nullptr, 16)); - } + out[j++] = Trinity::StringTo<uint8>(str.substr(i, 2), 16).value_or(0); } bool StringEqualI(std::string_view a, std::string_view b) |