aboutsummaryrefslogtreecommitdiff
path: root/CRT
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2023-09-27 00:10:24 +0200
committerToni Uhlig <matzeton@googlemail.com>2023-09-27 00:10:24 +0200
commit54f3087873fa1083c809939e74caf1ff29efc9d7 (patch)
treeb26e5b601cb848af1d1a3f47cf4a8bf37eac58d1 /CRT
parenta6d87015eb69fbdb18266cc5c59309140d942667 (diff)
Added `::to_string_hex()`.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'CRT')
-rw-r--r--CRT/eastl_compat.cpp47
-rw-r--r--CRT/eastl_compat.hpp7
2 files changed, 53 insertions, 1 deletions
diff --git a/CRT/eastl_compat.cpp b/CRT/eastl_compat.cpp
index cc2df45..e252f5f 100644
--- a/CRT/eastl_compat.cpp
+++ b/CRT/eastl_compat.cpp
@@ -123,6 +123,50 @@ eastl::string to_string(double value)
return "";
}
+template <typename T>
+static eastl::string to_string_hex(T w, size_t hex_len = sizeof(T) << 1)
+{
+ static const char * const digits = "0123456789ABCDEF";
+ const size_t len = sizeof(T) << 1;
+
+ if (hex_len < len)
+ hex_len = len;
+ eastl::string rc(hex_len, '0');
+ for (size_t i = hex_len - len, j = (hex_len - 1) * 4; i < hex_len; ++i, j -= 4)
+ rc[i] = digits[(w >> j) & 0x0f];
+ return rc;
+}
+
+eastl::string to_string_hex(int value, size_t fill_width)
+{
+ return to_string_hex<int>(value, fill_width);
+}
+
+eastl::string to_string_hex(long value, size_t fill_width)
+{
+ return to_string_hex<long>(value, fill_width);
+}
+
+eastl::string to_string_hex(long long value, size_t fill_width)
+{
+ return to_string_hex<long long>(value, fill_width);
+}
+
+eastl::string to_string_hex(unsigned int value, size_t fill_width)
+{
+ return to_string_hex<unsigned int>(value, fill_width);
+}
+
+eastl::string to_string_hex(unsigned long int value, size_t fill_width)
+{
+ return to_string_hex<unsigned long int>(value, fill_width);
+}
+
+eastl::string to_string_hex(unsigned long long int value, size_t fill_width)
+{
+ return to_string_hex<unsigned long long int>(value, fill_width);
+}
+
#ifndef NATIVE
eastl::string from_unicode(wchar_t * wstr, unsigned short wlen, unsigned short wmax)
{
@@ -133,7 +177,8 @@ eastl::string from_unicode(wchar_t * wstr, unsigned short wlen, unsigned short w
unicode.Length = wlen;
unicode.MaximumLength = (wmax > 0 ? wmax : wlen);
- if (NT_SUCCESS(RtlUnicodeStringToAnsiString(&ansi, &unicode, TRUE))) {
+ if (NT_SUCCESS(RtlUnicodeStringToAnsiString(&ansi, &unicode, TRUE)))
+ {
eastl::string result(ansi.Buffer, ansi.Length);
RtlFreeAnsiString(&ansi);
return result;
diff --git a/CRT/eastl_compat.hpp b/CRT/eastl_compat.hpp
index 442dc03..2459e75 100644
--- a/CRT/eastl_compat.hpp
+++ b/CRT/eastl_compat.hpp
@@ -12,6 +12,13 @@ eastl::string to_string(unsigned long long int value);
eastl::string to_string(float value);
eastl::string to_string(double value);
+eastl::string to_string_hex(int value, size_t fill_width = 0);
+eastl::string to_string_hex(long value, size_t fill_width = 0);
+eastl::string to_string_hex(long long value, size_t fill_width = 0);
+eastl::string to_string_hex(unsigned int value, size_t fill_width = 0);
+eastl::string to_string_hex(unsigned long int value, size_t fill_width = 0);
+eastl::string to_string_hex(unsigned long long int value, size_t fill_width = 0);
+
#ifndef NATIVE
eastl::string from_unicode(wchar_t * wstr, unsigned short wlen, unsigned short wmax = 0);
#endif