/ src / crypto / hex_base.cpp
hex_base.cpp
 1  // Copyright (c) 2009-present The Bitcoin Core developers
 2  // Distributed under the MIT software license, see the accompanying
 3  // file COPYING or http://www.opensource.org/licenses/mit-license.php.
 4  
 5  #include <crypto/hex_base.h>
 6  
 7  #include <array>
 8  #include <cassert>
 9  #include <cstring>
10  #include <string>
11  
12  namespace {
13  
14  using ByteAsHex = std::array<char, 2>;
15  
16  constexpr std::array<ByteAsHex, 256> CreateByteToHexMap()
17  {
18      constexpr char hexmap[16] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
19  
20      std::array<ByteAsHex, 256> byte_to_hex{};
21      for (size_t i = 0; i < byte_to_hex.size(); ++i) {
22          byte_to_hex[i][0] = hexmap[i >> 4];
23          byte_to_hex[i][1] = hexmap[i & 15];
24      }
25      return byte_to_hex;
26  }
27  
28  } // namespace
29  
30  std::string HexStr(const std::span<const uint8_t> s)
31  {
32      std::string rv(s.size() * 2, '\0');
33      static constexpr auto byte_to_hex = CreateByteToHexMap();
34      static_assert(sizeof(byte_to_hex) == 512);
35  
36      char* it = rv.data();
37      for (uint8_t v : s) {
38          std::memcpy(it, byte_to_hex[v].data(), 2);
39          it += 2;
40      }
41  
42      assert(it == rv.data() + rv.size());
43      return rv;
44  }
45  
46  const signed char p_util_hexdigit[256] =
47  { -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
48    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
49    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
50    0,1,2,3,4,5,6,7,8,9,-1,-1,-1,-1,-1,-1,
51    -1,0xa,0xb,0xc,0xd,0xe,0xf,-1,-1,-1,-1,-1,-1,-1,-1,-1,
52    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
53    -1,0xa,0xb,0xc,0xd,0xe,0xf,-1,-1,-1,-1,-1,-1,-1,-1,-1,
54    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
55    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
56    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
57    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
58    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
59    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
60    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
61    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
62    -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, };
63  
64  signed char HexDigit(char c)
65  {
66      return p_util_hexdigit[(unsigned char)c];
67  }
68