Bitcoin ABC 0.26.3
P2P Digital Currency
Loading...
Searching...
No Matches
sha256.h
Go to the documentation of this file.
1// Copyright (c) 2014-2016 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#ifndef BITCOIN_CRYPTO_SHA256_H
6#define BITCOIN_CRYPTO_SHA256_H
7
8#include <cstdint>
9#include <cstdlib>
10#include <string>
11
13class CSHA256 {
14private:
18
19public:
20 static const size_t OUTPUT_SIZE = 32;
21
22 CSHA256();
23 CSHA256 &Write(const uint8_t *data, size_t len);
24 void Finalize(uint8_t hash[OUTPUT_SIZE]);
25 CSHA256 &Reset();
26};
27
32std::string SHA256AutoDetect();
33
40void SHA256D64(uint8_t *output, const uint8_t *input, size_t blocks);
41
42#endif // BITCOIN_CRYPTO_SHA256_H
A hasher class for SHA-256.
Definition sha256.h:13
CSHA256 & Reset()
Definition sha256.cpp:860
uint8_t buf[64]
Definition sha256.h:16
CSHA256 & Write(const uint8_t *data, size_t len)
Definition sha256.cpp:819
static const size_t OUTPUT_SIZE
Definition sha256.h:20
void Finalize(uint8_t hash[OUTPUT_SIZE])
Definition sha256.cpp:844
uint64_t bytes
Definition sha256.h:17
uint32_t s[8]
Definition sha256.h:15
CSHA256()
Definition sha256.cpp:815
T GetRand(T nMax=std::numeric_limits< T >::max()) noexcept
Generate a uniform random integer of type T in the range [0..nMax) nMax defaults to std::numeric_limi...
Definition random.h:85
void SHA256D64(uint8_t *output, const uint8_t *input, size_t blocks)
Compute multiple double-SHA256's of 64-byte blobs.
Definition sha256.cpp:866
std::string SHA256AutoDetect()
Autodetect the best available SHA256 implementation.
Definition sha256.cpp:746