summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorGravatar Lioncash2019-06-12 17:27:06 -0400
committerGravatar Lioncash2019-06-12 17:54:05 -0400
commita62088539ed02a8569814601b3b99b713c5d8a34 (patch)
tree03fe279e7651c55291f702f5a8b518cb07e35812 /src/common
parentMerge pull request #2578 from lioncash/cnmt (diff)
downloadyuzu-a62088539ed02a8569814601b3b99b713c5d8a34.tar.gz
yuzu-a62088539ed02a8569814601b3b99b713c5d8a34.tar.xz
yuzu-a62088539ed02a8569814601b3b99b713c5d8a34.zip
common/hex_util: Combine HexVectorToString() and HexArrayToString()
These can be generified together by using a concept type to designate them. This also has the benefit of not making copies of potentially very large arrays.
Diffstat (limited to 'src/common')
-rw-r--r--src/common/hex_util.cpp7
-rw-r--r--src/common/hex_util.h11
2 files changed, 7 insertions, 11 deletions
diff --git a/src/common/hex_util.cpp b/src/common/hex_util.cpp
index 5b63f9e81..c2f6cf0f6 100644
--- a/src/common/hex_util.cpp
+++ b/src/common/hex_util.cpp
@@ -30,13 +30,6 @@ std::vector<u8> HexStringToVector(std::string_view str, bool little_endian) {
30 return out; 30 return out;
31} 31}
32 32
33std::string HexVectorToString(const std::vector<u8>& vector, bool upper) {
34 std::string out;
35 for (u8 c : vector)
36 out += fmt::format(upper ? "{:02X}" : "{:02x}", c);
37 return out;
38}
39
40std::array<u8, 16> operator""_array16(const char* str, std::size_t len) { 33std::array<u8, 16> operator""_array16(const char* str, std::size_t len) {
41 if (len != 32) { 34 if (len != 32) {
42 LOG_ERROR(Common, 35 LOG_ERROR(Common,
diff --git a/src/common/hex_util.h b/src/common/hex_util.h
index 68f003cb6..a64c9b485 100644
--- a/src/common/hex_util.h
+++ b/src/common/hex_util.h
@@ -7,6 +7,7 @@
7#include <array> 7#include <array>
8#include <cstddef> 8#include <cstddef>
9#include <string> 9#include <string>
10#include <type_traits>
10#include <vector> 11#include <vector>
11#include <fmt/format.h> 12#include <fmt/format.h>
12#include "common/common_types.h" 13#include "common/common_types.h"
@@ -30,13 +31,15 @@ std::array<u8, Size> HexStringToArray(std::string_view str) {
30 return out; 31 return out;
31} 32}
32 33
33std::string HexVectorToString(const std::vector<u8>& vector, bool upper = true); 34template <typename ContiguousContainer>
35std::string HexToString(const ContiguousContainer& data, bool upper = true) {
36 static_assert(std::is_same_v<typename ContiguousContainer::value_type, u8>,
37 "Underlying type within the contiguous container must be u8.");
34 38
35template <std::size_t Size>
36std::string HexArrayToString(std::array<u8, Size> array, bool upper = true) {
37 std::string out; 39 std::string out;
38 for (u8 c : array) 40 for (const u8 c : data) {
39 out += fmt::format(upper ? "{:02X}" : "{:02x}", c); 41 out += fmt::format(upper ? "{:02X}" : "{:02x}", c);
42 }
40 return out; 43 return out;
41} 44}
42 45