30 void Finalize(std::span<unsigned char> output) {
38 sha.
Write(input.data(), input.size());
55 void Finalize(std::span<unsigned char> output) {
63 sha.
Write(input.data(), input.size());
83 template<
typename T1,
typename T2>
106 void write(std::span<const std::byte> src)
140 template <
typename T>
149 template <
typename Source>
158 void read(std::span<std::byte> dst)
166 std::byte
data[1024];
167 while (num_bytes > 0) {
168 size_t now = std::min<size_t>(num_bytes, 1024);
174 template <
typename T>
183 template <
typename Source>
192 void write(std::span<const std::byte> src)
198 template <
typename T>
209 unsigned int MurmurHash3(
unsigned int nHashSeed, std::span<const unsigned char> vDataToHash);
211 void BIP32Hash(
const ChainCode &chainCode,
unsigned int nChild,
unsigned char header,
const unsigned char data[32],
unsigned char output[64]);
229 #endif // BITCOIN_HASH_H uint256 GetHash()
Compute the double-SHA256 hash of all data written to this object.
CSHA256 & Write(const unsigned char *data, size_t len)
void BIP32Hash(const ChainCode &chainCode, unsigned int nChild, unsigned char header, const unsigned char data[32], unsigned char output[64])
constexpr auto MakeUCharSpan(const V &v) -> decltype(UCharSpanCast(std::span
Like the std::span constructor, but for (const) unsigned char member types only.
unsigned int MurmurHash3(unsigned int nHashSeed, std::span< const unsigned char > vDataToHash)
CHash160 & Write(std::span< const unsigned char > input)
void read(std::span< std::byte > dst)
uint160 RIPEMD160(std::span< const unsigned char > data)
Compute the 160-bit RIPEMD-160 hash of an array.
void write(std::span< const std::byte > src)
A hasher class for Bitcoin's 256-bit hash (double SHA-256).
HashWriter & operator<<(const T &obj)
static const size_t OUTPUT_SIZE
void ignore(size_t num_bytes)
HashedSourceWriter(Source &source LIFETIMEBOUND)
uint256 SHA256Uint256(const uint256 &input)
Single-SHA256 a 32-byte input (represented as uint256).
void Unserialize(Stream &, V)=delete
uint256 GetSHA256()
Compute the SHA256 hash of all data written to this object.
static const size_t OUTPUT_SIZE
HashVerifier(Source &source LIFETIMEBOUND)
void Finalize(std::span< unsigned char > output)
A writer stream (for serialization) that computes a 256-bit hash.
uint64_t ReadLE64(const B *ptr)
void write(std::span< const std::byte > src)
void Finalize(unsigned char hash[OUTPUT_SIZE])
HashWriter TaggedHash(const std::string &tag)
Return a HashWriter primed for tagged hashes (as specified in BIP 340).
CRIPEMD160 & Write(const unsigned char *data, size_t len)
uint160 Hash160(const T1 &in1)
Compute the 160-bit hash an object.
void Finalize(std::span< unsigned char > output)
HashedSourceWriter & operator<<(const T &obj)
HashVerifier< Source > & operator>>(T &&obj)
uint64_t GetCheapHash()
Returns the first 64 bits from the resulting hash.
static const size_t OUTPUT_SIZE
static const size_t OUTPUT_SIZE
Writes data to an underlying source stream, while hashing the written data.
unsigned char * UCharCast(char *c)
Reads data from an underlying stream, while hashing the read data.
uint256 Hash(const T &in1)
Compute the 256-bit hash of an object.
A hasher class for Bitcoin's 160-bit hash (SHA-256 + RIPEMD-160).
void Finalize(unsigned char hash[OUTPUT_SIZE])
A hasher class for SHA-256.
A hasher class for RIPEMD-160.
CHash256 & Write(std::span< const unsigned char > input)