mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 18:53:23 -03:00
Merge #19660: refactor: Make HexStr take a span
0a8aa626dd
refactor: Make HexStr take a span (Wladimir J. van der Laan) Pull request description: Make `HexSt`r take a span of bytes, instead of an awkward pair of templated iterators. This simplifies most of the uses. ACKs for top commit: elichai: Code review ACK0a8aa626dd
hebasto: re-ACK0a8aa626dd
jonatack: re-ACK0a8aa626dd
Tree-SHA512: 6e178ece5cbac62119c857a10299b1e85422938084c3f03063e17119a5129e0c28016e05a6fabaa4c271a7e0a37c7cd89fa47c435ee19b38a5acfe80d00de992
This commit is contained in:
commit
b75f2ad72d
16 changed files with 50 additions and 70 deletions
|
@ -48,13 +48,14 @@ std::string FormatScript(const CScript& script)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (vch.size() > 0) {
|
if (vch.size() > 0) {
|
||||||
ret += strprintf("0x%x 0x%x ", HexStr(it2, it - vch.size()), HexStr(it - vch.size(), it));
|
ret += strprintf("0x%x 0x%x ", HexStr(std::vector<uint8_t>(it2, it - vch.size())),
|
||||||
|
HexStr(std::vector<uint8_t>(it - vch.size(), it)));
|
||||||
} else {
|
} else {
|
||||||
ret += strprintf("0x%x ", HexStr(it2, it));
|
ret += strprintf("0x%x ", HexStr(std::vector<uint8_t>(it2, it)));
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
ret += strprintf("0x%x ", HexStr(it2, script.end()));
|
ret += strprintf("0x%x ", HexStr(std::vector<uint8_t>(it2, script.end())));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return ret.substr(0, ret.size() - 1);
|
return ret.substr(0, ret.size() - 1);
|
||||||
|
|
|
@ -722,8 +722,8 @@ CNetMessage V1TransportDeserializer::GetMessage(const CMessageHeader::MessageSta
|
||||||
if (!msg.m_valid_checksum) {
|
if (!msg.m_valid_checksum) {
|
||||||
LogPrint(BCLog::NET, "CHECKSUM ERROR (%s, %u bytes), expected %s was %s\n",
|
LogPrint(BCLog::NET, "CHECKSUM ERROR (%s, %u bytes), expected %s was %s\n",
|
||||||
SanitizeString(msg.m_command), msg.m_message_size,
|
SanitizeString(msg.m_command), msg.m_message_size,
|
||||||
HexStr(hash.begin(), hash.begin()+CMessageHeader::CHECKSUM_SIZE),
|
HexStr(Span<uint8_t>(hash.begin(), hash.begin() + CMessageHeader::CHECKSUM_SIZE)),
|
||||||
HexStr(hdr.pchChecksum, hdr.pchChecksum+CMessageHeader::CHECKSUM_SIZE));
|
HexStr(hdr.pchChecksum));
|
||||||
}
|
}
|
||||||
|
|
||||||
// store receive time
|
// store receive time
|
||||||
|
|
|
@ -1348,7 +1348,7 @@ UniValue finalizepsbt(const JSONRPCRequest& request)
|
||||||
|
|
||||||
if (complete && extract) {
|
if (complete && extract) {
|
||||||
ssTx << mtx;
|
ssTx << mtx;
|
||||||
result_str = HexStr(ssTx.str());
|
result_str = HexStr(ssTx);
|
||||||
result.pushKV("hex", result_str);
|
result.pushKV("hex", result_str);
|
||||||
} else {
|
} else {
|
||||||
ssTx << psbtx;
|
ssTx << psbtx;
|
||||||
|
|
|
@ -78,7 +78,7 @@ bool GenerateAuthCookie(std::string *cookie_out)
|
||||||
const size_t COOKIE_SIZE = 32;
|
const size_t COOKIE_SIZE = 32;
|
||||||
unsigned char rand_pwd[COOKIE_SIZE];
|
unsigned char rand_pwd[COOKIE_SIZE];
|
||||||
GetRandBytes(rand_pwd, COOKIE_SIZE);
|
GetRandBytes(rand_pwd, COOKIE_SIZE);
|
||||||
std::string cookie = COOKIEAUTH_USER + ":" + HexStr(rand_pwd, rand_pwd+COOKIE_SIZE);
|
std::string cookie = COOKIEAUTH_USER + ":" + HexStr(rand_pwd);
|
||||||
|
|
||||||
/** the umask determines what permissions are used to create this file -
|
/** the umask determines what permissions are used to create this file -
|
||||||
* these are set to 077 in init.cpp unless overridden with -sysperms.
|
* these are set to 077 in init.cpp unless overridden with -sysperms.
|
||||||
|
|
|
@ -260,7 +260,7 @@ public:
|
||||||
UniValue obj(UniValue::VOBJ);
|
UniValue obj(UniValue::VOBJ);
|
||||||
obj.pushKV("iswitness", true);
|
obj.pushKV("iswitness", true);
|
||||||
obj.pushKV("witness_version", (int)id.version);
|
obj.pushKV("witness_version", (int)id.version);
|
||||||
obj.pushKV("witness_program", HexStr(id.program, id.program + id.length));
|
obj.pushKV("witness_program", HexStr(Span<const unsigned char>(id.program, id.length)));
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -190,7 +190,7 @@ class OriginPubkeyProvider final : public PubkeyProvider
|
||||||
|
|
||||||
std::string OriginString() const
|
std::string OriginString() const
|
||||||
{
|
{
|
||||||
return HexStr(std::begin(m_origin.fingerprint), std::end(m_origin.fingerprint)) + FormatHDKeypath(m_origin.path);
|
return HexStr(m_origin.fingerprint) + FormatHDKeypath(m_origin.path);
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -183,7 +183,7 @@ static void TestHKDF_SHA256_32(const std::string &ikm_hex, const std::string &sa
|
||||||
CHKDF_HMAC_SHA256_L32 hkdf32(initial_key_material.data(), initial_key_material.size(), salt_stringified);
|
CHKDF_HMAC_SHA256_L32 hkdf32(initial_key_material.data(), initial_key_material.size(), salt_stringified);
|
||||||
unsigned char out[32];
|
unsigned char out[32];
|
||||||
hkdf32.Expand32(info_stringified, out);
|
hkdf32.Expand32(info_stringified, out);
|
||||||
BOOST_CHECK(HexStr(out, out + 32) == okm_check_hex);
|
BOOST_CHECK(HexStr(out) == okm_check_hex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::string LongTestString()
|
static std::string LongTestString()
|
||||||
|
|
|
@ -241,7 +241,7 @@ BOOST_FIXTURE_TEST_CASE(Merge, MergeTestingSetup)
|
||||||
|
|
||||||
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
||||||
out_sha.Finalize(out_sha_bytes);
|
out_sha.Finalize(out_sha_bytes);
|
||||||
std::string out_sha_hex = HexStr(std::begin(out_sha_bytes), std::end(out_sha_bytes));
|
std::string out_sha_hex = HexStr(out_sha_bytes);
|
||||||
|
|
||||||
// If check below fails, should manually dump the results with:
|
// If check below fails, should manually dump the results with:
|
||||||
//
|
//
|
||||||
|
|
|
@ -105,47 +105,24 @@ BOOST_AUTO_TEST_CASE(util_ParseHex)
|
||||||
BOOST_AUTO_TEST_CASE(util_HexStr)
|
BOOST_AUTO_TEST_CASE(util_HexStr)
|
||||||
{
|
{
|
||||||
BOOST_CHECK_EQUAL(
|
BOOST_CHECK_EQUAL(
|
||||||
HexStr(ParseHex_expected, ParseHex_expected + sizeof(ParseHex_expected)),
|
HexStr(ParseHex_expected),
|
||||||
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f");
|
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f");
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
BOOST_CHECK_EQUAL(
|
||||||
HexStr(ParseHex_expected + sizeof(ParseHex_expected),
|
HexStr(Span<const unsigned char>(
|
||||||
ParseHex_expected + sizeof(ParseHex_expected)),
|
ParseHex_expected + sizeof(ParseHex_expected),
|
||||||
|
ParseHex_expected + sizeof(ParseHex_expected))),
|
||||||
"");
|
"");
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
BOOST_CHECK_EQUAL(
|
||||||
HexStr(ParseHex_expected, ParseHex_expected),
|
HexStr(Span<const unsigned char>(ParseHex_expected, ParseHex_expected)),
|
||||||
"");
|
"");
|
||||||
|
|
||||||
std::vector<unsigned char> ParseHex_vec(ParseHex_expected, ParseHex_expected + 5);
|
std::vector<unsigned char> ParseHex_vec(ParseHex_expected, ParseHex_expected + 5);
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
BOOST_CHECK_EQUAL(
|
||||||
HexStr(ParseHex_vec.rbegin(), ParseHex_vec.rend()),
|
HexStr(ParseHex_vec),
|
||||||
"b0fd8a6704"
|
"04678afdb0"
|
||||||
);
|
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
|
||||||
HexStr(std::reverse_iterator<const uint8_t *>(ParseHex_expected),
|
|
||||||
std::reverse_iterator<const uint8_t *>(ParseHex_expected)),
|
|
||||||
""
|
|
||||||
);
|
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
|
||||||
HexStr(std::reverse_iterator<const uint8_t *>(ParseHex_expected + 1),
|
|
||||||
std::reverse_iterator<const uint8_t *>(ParseHex_expected)),
|
|
||||||
"04"
|
|
||||||
);
|
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
|
||||||
HexStr(std::reverse_iterator<const uint8_t *>(ParseHex_expected + 5),
|
|
||||||
std::reverse_iterator<const uint8_t *>(ParseHex_expected)),
|
|
||||||
"b0fd8a6704"
|
|
||||||
);
|
|
||||||
|
|
||||||
BOOST_CHECK_EQUAL(
|
|
||||||
HexStr(std::reverse_iterator<const uint8_t *>(ParseHex_expected + 65),
|
|
||||||
std::reverse_iterator<const uint8_t *>(ParseHex_expected)),
|
|
||||||
"5f1df16b2b704c8a578d0bbaf74d385cde12c11ee50455f3c438ef4c3fbcf649b6de611feae06279a60939e028a8d65c10b73071a6f16719274855feb0fd8a6704"
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1022,7 +999,7 @@ BOOST_FIXTURE_TEST_CASE(util_ArgsMerge, ArgsMergeTestingSetup)
|
||||||
|
|
||||||
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
||||||
out_sha.Finalize(out_sha_bytes);
|
out_sha.Finalize(out_sha_bytes);
|
||||||
std::string out_sha_hex = HexStr(std::begin(out_sha_bytes), std::end(out_sha_bytes));
|
std::string out_sha_hex = HexStr(out_sha_bytes);
|
||||||
|
|
||||||
// If check below fails, should manually dump the results with:
|
// If check below fails, should manually dump the results with:
|
||||||
//
|
//
|
||||||
|
@ -1125,7 +1102,7 @@ BOOST_FIXTURE_TEST_CASE(util_ChainMerge, ChainMergeTestingSetup)
|
||||||
|
|
||||||
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
unsigned char out_sha_bytes[CSHA256::OUTPUT_SIZE];
|
||||||
out_sha.Finalize(out_sha_bytes);
|
out_sha.Finalize(out_sha_bytes);
|
||||||
std::string out_sha_hex = HexStr(std::begin(out_sha_bytes), std::end(out_sha_bytes));
|
std::string out_sha_hex = HexStr(out_sha_bytes);
|
||||||
|
|
||||||
// If check below fails, should manually dump the results with:
|
// If check below fails, should manually dump the results with:
|
||||||
//
|
//
|
||||||
|
|
|
@ -19,7 +19,11 @@ base_blob<BITS>::base_blob(const std::vector<unsigned char>& vch)
|
||||||
template <unsigned int BITS>
|
template <unsigned int BITS>
|
||||||
std::string base_blob<BITS>::GetHex() const
|
std::string base_blob<BITS>::GetHex() const
|
||||||
{
|
{
|
||||||
return HexStr(std::reverse_iterator<const uint8_t*>(m_data + sizeof(m_data)), std::reverse_iterator<const uint8_t*>(m_data));
|
uint8_t m_data_rev[WIDTH];
|
||||||
|
for (int i = 0; i < WIDTH; ++i) {
|
||||||
|
m_data_rev[i] = m_data[WIDTH - 1 - i];
|
||||||
|
}
|
||||||
|
return HexStr(m_data_rev);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <unsigned int BITS>
|
template <unsigned int BITS>
|
||||||
|
|
|
@ -569,3 +569,16 @@ std::string Capitalize(std::string str)
|
||||||
str[0] = ToUpper(str.front());
|
str[0] = ToUpper(str.front());
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string HexStr(const Span<const uint8_t> s)
|
||||||
|
{
|
||||||
|
std::string rv;
|
||||||
|
static constexpr char hexmap[16] = { '0', '1', '2', '3', '4', '5', '6', '7',
|
||||||
|
'8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
|
||||||
|
rv.reserve(s.size() * 2);
|
||||||
|
for (uint8_t v: s) {
|
||||||
|
rv.push_back(hexmap[v >> 4]);
|
||||||
|
rv.push_back(hexmap[v & 15]);
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#define BITCOIN_UTIL_STRENCODINGS_H
|
#define BITCOIN_UTIL_STRENCODINGS_H
|
||||||
|
|
||||||
#include <attributes.h>
|
#include <attributes.h>
|
||||||
|
#include <span.h>
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
@ -119,27 +120,11 @@ NODISCARD bool ParseUInt64(const std::string& str, uint64_t *out);
|
||||||
*/
|
*/
|
||||||
NODISCARD bool ParseDouble(const std::string& str, double *out);
|
NODISCARD bool ParseDouble(const std::string& str, double *out);
|
||||||
|
|
||||||
template<typename T>
|
/**
|
||||||
std::string HexStr(const T itbegin, const T itend)
|
* Convert a span of bytes to a lower-case hexadecimal string.
|
||||||
{
|
*/
|
||||||
std::string rv;
|
std::string HexStr(const Span<const uint8_t> s);
|
||||||
static const char hexmap[16] = { '0', '1', '2', '3', '4', '5', '6', '7',
|
inline std::string HexStr(const Span<const char> s) { return HexStr(MakeUCharSpan(s)); }
|
||||||
'8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
|
|
||||||
rv.reserve(std::distance(itbegin, itend) * 2);
|
|
||||||
for(T it = itbegin; it < itend; ++it)
|
|
||||||
{
|
|
||||||
unsigned char val = (unsigned char)(*it);
|
|
||||||
rv.push_back(hexmap[val>>4]);
|
|
||||||
rv.push_back(hexmap[val&15]);
|
|
||||||
}
|
|
||||||
return rv;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline std::string HexStr(const T& vch)
|
|
||||||
{
|
|
||||||
return HexStr(vch.begin(), vch.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Format a paragraph of text to a fixed width, adding spaces for
|
* Format a paragraph of text to a fixed width, adding spaces for
|
||||||
|
|
|
@ -1199,8 +1199,8 @@ bool ReadRawBlockFromDisk(std::vector<uint8_t>& block, const FlatFilePos& pos, c
|
||||||
|
|
||||||
if (memcmp(blk_start, message_start, CMessageHeader::MESSAGE_START_SIZE)) {
|
if (memcmp(blk_start, message_start, CMessageHeader::MESSAGE_START_SIZE)) {
|
||||||
return error("%s: Block magic mismatch for %s: %s versus expected %s", __func__, pos.ToString(),
|
return error("%s: Block magic mismatch for %s: %s versus expected %s", __func__, pos.ToString(),
|
||||||
HexStr(blk_start, blk_start + CMessageHeader::MESSAGE_START_SIZE),
|
HexStr(blk_start),
|
||||||
HexStr(message_start, message_start + CMessageHeader::MESSAGE_START_SIZE));
|
HexStr(message_start));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (blk_size > MAX_SIZE) {
|
if (blk_size > MAX_SIZE) {
|
||||||
|
|
|
@ -38,7 +38,7 @@ void CheckUniqueFileid(const BerkeleyEnvironment& env, const std::string& filena
|
||||||
for (const auto& item : env.m_fileids) {
|
for (const auto& item : env.m_fileids) {
|
||||||
if (fileid == item.second && &fileid != &item.second) {
|
if (fileid == item.second && &fileid != &item.second) {
|
||||||
throw std::runtime_error(strprintf("BerkeleyDatabase: Can't open database %s (duplicates fileid %s from %s)", filename,
|
throw std::runtime_error(strprintf("BerkeleyDatabase: Can't open database %s (duplicates fileid %s from %s)", filename,
|
||||||
HexStr(std::begin(item.second.value), std::end(item.second.value)), item.first));
|
HexStr(item.second.value), item.first));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ std::string static EncodeDumpString(const std::string &str) {
|
||||||
std::stringstream ret;
|
std::stringstream ret;
|
||||||
for (const unsigned char c : str) {
|
for (const unsigned char c : str) {
|
||||||
if (c <= 32 || c >= 128 || c == '%') {
|
if (c <= 32 || c >= 128 || c == '%') {
|
||||||
ret << '%' << HexStr(&c, &c + 1);
|
ret << '%' << HexStr(Span<const unsigned char>(&c, 1));
|
||||||
} else {
|
} else {
|
||||||
ret << c;
|
ret << c;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3688,7 +3688,7 @@ UniValue getaddressinfo(const JSONRPCRequest& request)
|
||||||
if (meta->has_key_origin) {
|
if (meta->has_key_origin) {
|
||||||
ret.pushKV("hdkeypath", WriteHDKeypath(meta->key_origin.path));
|
ret.pushKV("hdkeypath", WriteHDKeypath(meta->key_origin.path));
|
||||||
ret.pushKV("hdseedid", meta->hd_seed_id.GetHex());
|
ret.pushKV("hdseedid", meta->hd_seed_id.GetHex());
|
||||||
ret.pushKV("hdmasterfingerprint", HexStr(meta->key_origin.fingerprint, meta->key_origin.fingerprint + 4));
|
ret.pushKV("hdmasterfingerprint", HexStr(meta->key_origin.fingerprint));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue