diff options
author | bunnei <bunneidev@gmail.com> | 2018-10-08 12:30:33 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-08 12:30:33 -0400 |
commit | 6b48ba52712e5ea9cadb1177c06cb3ca65492c38 (patch) | |
tree | 365bb902d31fd5d5d585fc2f5d9e9dac274b02ec /src/common/hex_util.cpp | |
parent | fd891ee9c0342b603574e57ef178620439927256 (diff) | |
parent | 110d5784702282c594fe57f84f8d6bda21a82d50 (diff) |
Merge pull request #1424 from DarkLordZach/ips-witch
ips_layer: Add support for IPSwitch executable patches
Diffstat (limited to 'src/common/hex_util.cpp')
-rw-r--r-- | src/common/hex_util.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/common/hex_util.cpp b/src/common/hex_util.cpp index 589ae5cbf..5b63f9e81 100644 --- a/src/common/hex_util.cpp +++ b/src/common/hex_util.cpp @@ -18,6 +18,25 @@ u8 ToHexNibble(char c1) { return 0; } +std::vector<u8> HexStringToVector(std::string_view str, bool little_endian) { + std::vector<u8> out(str.size() / 2); + if (little_endian) { + for (std::size_t i = str.size() - 2; i <= str.size(); i -= 2) + out[i / 2] = (ToHexNibble(str[i]) << 4) | ToHexNibble(str[i + 1]); + } else { + for (std::size_t i = 0; i < str.size(); i += 2) + out[i / 2] = (ToHexNibble(str[i]) << 4) | ToHexNibble(str[i + 1]); + } + return out; +} + +std::string HexVectorToString(const std::vector<u8>& vector, bool upper) { + std::string out; + for (u8 c : vector) + out += fmt::format(upper ? "{:02X}" : "{:02x}", c); + return out; +} + std::array<u8, 16> operator""_array16(const char* str, std::size_t len) { if (len != 32) { LOG_ERROR(Common, |