Bitcoin Core  29.1.0
P2P Digital Currency
hex.cpp
Go to the documentation of this file.
1 // Copyright (c) 2019-2021 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 <core_io.h>
6 #include <primitives/block.h>
7 #include <pubkey.h>
8 #include <rpc/util.h>
9 #include <test/fuzz/fuzz.h>
10 #include <uint256.h>
11 #include <univalue.h>
12 #include <util/strencodings.h>
14 
15 #include <algorithm>
16 #include <cassert>
17 #include <cstdint>
18 #include <string>
19 #include <vector>
20 
22 {
23  const std::string random_hex_string(buffer.begin(), buffer.end());
24  const std::vector<unsigned char> data = ParseHex(random_hex_string);
25  const std::vector<std::byte> bytes{ParseHex<std::byte>(random_hex_string)};
26  assert(std::ranges::equal(AsBytes(Span{data}), bytes));
27  const std::string hex_data = HexStr(data);
28  if (IsHex(random_hex_string)) {
29  assert(ToLower(random_hex_string) == hex_data);
30  }
31  if (uint256::FromHex(random_hex_string)) {
32  assert(random_hex_string.length() == 64);
33  assert(Txid::FromHex(random_hex_string));
34  assert(Wtxid::FromHex(random_hex_string));
35  assert(uint256::FromUserHex(random_hex_string));
36  }
37  if (const auto result{uint256::FromUserHex(random_hex_string)}) {
38  const auto result_string{result->ToString()}; // ToString() returns a fixed-length string without "0x" prefix
39  assert(result_string.length() == 64);
40  assert(IsHex(result_string));
41  assert(TryParseHex(result_string));
42  assert(Txid::FromHex(result_string));
43  assert(Wtxid::FromHex(result_string));
44  assert(uint256::FromHex(result_string));
45  }
46  try {
47  (void)HexToPubKey(random_hex_string);
48  } catch (const UniValue&) {
49  }
50  CBlockHeader block_header;
51  (void)DecodeHexBlockHeader(block_header, random_hex_string);
52  CBlock block;
53  (void)DecodeHexBlk(block, random_hex_string);
54 }
bool DecodeHexBlk(CBlock &, const std::string &strHexBlk)
Definition: core_read.cpp:220
std::vector< Byte > ParseHex(std::string_view hex_str)
Like TryParseHex, but returns an empty vector on invalid input.
Definition: strencodings.h:68
assert(!tx.IsCoinBase())
Definition: block.h:68
bool IsHex(std::string_view str)
CPubKey HexToPubKey(const std::string &hex_in)
Definition: util.cpp:222
bool DecodeHexBlockHeader(CBlockHeader &, const std::string &hex_header)
Definition: core_read.cpp:206
static std::optional< uint256 > FromUserHex(std::string_view str)
Definition: uint256.h:204
FUZZ_TARGET(hex)
Definition: hex.cpp:21
static std::optional< uint256 > FromHex(std::string_view str)
Definition: uint256.h:203
std::string ToLower(std::string_view str)
Returns the lowercase equivalent of the given string.
auto result
Definition: common-types.h:74
std::string HexStr(const Span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Definition: hex_base.cpp:29
Span< const std::byte > AsBytes(Span< T > s) noexcept
Definition: span.h:258
std::optional< std::vector< Byte > > TryParseHex(std::string_view str)
Parse the hex string into bytes (uint8_t or std::byte).
A Span is an object that can refer to a contiguous sequence of objects.
Definition: span.h:97
static std::optional< transaction_identifier > FromHex(std::string_view hex)
Nodes collect new transactions into a block, hash them into a hash tree, and scan through nonce value...
Definition: block.h:21