diff options
Diffstat (limited to 'src/common/Utilities/Util.cpp')
-rw-r--r-- | src/common/Utilities/Util.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/common/Utilities/Util.cpp b/src/common/Utilities/Util.cpp index c374bff9cf1..fc2a9519a3f 100644 --- a/src/common/Utilities/Util.cpp +++ b/src/common/Utilities/Util.cpp @@ -818,10 +818,10 @@ std::string Trinity::Impl::ByteArrayToHexStr(uint8 const* bytes, size_t arrayLen } std::string result; - result.reserve(arrayLen * 2); - auto inserter = std::back_inserter(result); + result.resize(arrayLen * 2); + auto inserter = result.data(); for (int32 i = init; i != end; i += op) - Trinity::StringFormatTo(inserter, "{:02X}", bytes[i]); + inserter = Trinity::StringFormatTo(inserter, "{:02X}", bytes[i]); return result; } @@ -862,6 +862,16 @@ bool StringCompareLessI(std::string_view a, std::string_view b) return std::ranges::lexicographical_compare(a, b, {}, charToLower, charToLower); } +void StringReplaceAll(std::string* str, std::string_view text, std::string_view replacement) +{ + std::size_t pos = str->find(text, 0); + while (pos != std::string::npos) + { + str->replace(pos, text.length(), replacement); + pos = str->find(text, pos + replacement.length()); + } +} + std::string Trinity::Impl::GetTypeName(std::type_info const& info) { return boost::core::demangle(info.name()); |