Bitcoin Core 29.99.0
P2P Digital Currency
uint256.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-present The Bitcoin Core developers
3// Distributed under the MIT software license, see the accompanying
4// file COPYING or http://www.opensource.org/licenses/mit-license.php.
5
6#ifndef BITCOIN_UINT256_H
7#define BITCOIN_UINT256_H
8
9#include <crypto/common.h>
10#include <span.h>
11#include <util/strencodings.h>
12#include <util/string.h>
13
14#include <algorithm>
15#include <array>
16#include <cassert>
17#include <cstdint>
18#include <cstring>
19#include <optional>
20#include <string>
21#include <string_view>
22
24template<unsigned int BITS>
26{
27protected:
28 static constexpr int WIDTH = BITS / 8;
29 static_assert(BITS % 8 == 0, "base_blob currently only supports whole bytes.");
30 std::array<uint8_t, WIDTH> m_data;
31 static_assert(WIDTH == sizeof(m_data), "Sanity check");
32
33public:
34 /* construct 0 value by default */
35 constexpr base_blob() : m_data() {}
36
37 /* constructor for constants between 1 and 255 */
38 constexpr explicit base_blob(uint8_t v) : m_data{v} {}
39
40 constexpr explicit base_blob(std::span<const unsigned char> vch)
41 {
42 assert(vch.size() == WIDTH);
43 std::copy(vch.begin(), vch.end(), m_data.begin());
44 }
45
46 consteval explicit base_blob(std::string_view hex_str);
47
48 constexpr bool IsNull() const
49 {
50 return std::all_of(m_data.begin(), m_data.end(), [](uint8_t val) {
51 return val == 0;
52 });
53 }
54
55 constexpr void SetNull()
56 {
57 std::fill(m_data.begin(), m_data.end(), 0);
58 }
59
64 constexpr int Compare(const base_blob& other) const { return std::memcmp(m_data.data(), other.m_data.data(), WIDTH); }
65
66 friend constexpr bool operator==(const base_blob& a, const base_blob& b) { return a.Compare(b) == 0; }
67 friend constexpr bool operator!=(const base_blob& a, const base_blob& b) { return a.Compare(b) != 0; }
68 friend constexpr bool operator<(const base_blob& a, const base_blob& b) { return a.Compare(b) < 0; }
69
94 std::string GetHex() const;
95 std::string ToString() const;
98 constexpr const unsigned char* data() const { return m_data.data(); }
99 constexpr unsigned char* data() { return m_data.data(); }
100
101 constexpr unsigned char* begin() { return m_data.data(); }
102 constexpr unsigned char* end() { return m_data.data() + WIDTH; }
103
104 constexpr const unsigned char* begin() const { return m_data.data(); }
105 constexpr const unsigned char* end() const { return m_data.data() + WIDTH; }
106
107 static constexpr unsigned int size() { return WIDTH; }
108
109 constexpr uint64_t GetUint64(int pos) const { return ReadLE64(m_data.data() + pos * 8); }
110
111 template<typename Stream>
112 void Serialize(Stream& s) const
113 {
114 s << std::span(m_data);
115 }
116
117 template<typename Stream>
118 void Unserialize(Stream& s)
119 {
121 }
122};
123
124template <unsigned int BITS>
125consteval base_blob<BITS>::base_blob(std::string_view hex_str)
126{
127 if (hex_str.length() != m_data.size() * 2) throw "Hex string must fit exactly";
128 auto str_it = hex_str.rbegin();
129 for (auto& elem : m_data) {
130 auto lo = util::ConstevalHexDigit(*(str_it++));
131 elem = (util::ConstevalHexDigit(*(str_it++)) << 4) | lo;
132 }
133}
134
135namespace detail {
142template <class uintN_t>
143std::optional<uintN_t> FromHex(std::string_view str)
144{
145 if (uintN_t::size() * 2 != str.size() || !IsHex(str)) return std::nullopt;
146 uintN_t rv;
147 unsigned char* p1 = rv.begin();
148 unsigned char* pend = rv.end();
149 size_t digits = str.size();
150 while (digits > 0 && p1 < pend) {
151 *p1 = ::HexDigit(str[--digits]);
152 if (digits > 0) {
153 *p1 |= ((unsigned char)::HexDigit(str[--digits]) << 4);
154 p1++;
155 }
156 }
157 return rv;
158}
166template <class uintN_t>
167std::optional<uintN_t> FromUserHex(std::string_view input)
168{
169 input = util::RemovePrefixView(input, "0x");
170 constexpr auto expected_size{uintN_t::size() * 2};
171 if (input.size() < expected_size) {
172 auto padded = std::string(expected_size, '0');
173 std::copy(input.begin(), input.end(), padded.begin() + expected_size - input.size());
174 return FromHex<uintN_t>(padded);
175 }
176 return FromHex<uintN_t>(input);
177}
178} // namespace detail
179
184class uint160 : public base_blob<160> {
185public:
186 static std::optional<uint160> FromHex(std::string_view str) { return detail::FromHex<uint160>(str); }
187 constexpr uint160() = default;
188 constexpr explicit uint160(std::span<const unsigned char> vch) : base_blob<160>(vch) {}
189};
190
196class uint256 : public base_blob<256> {
197public:
198 static std::optional<uint256> FromHex(std::string_view str) { return detail::FromHex<uint256>(str); }
199 static std::optional<uint256> FromUserHex(std::string_view str) { return detail::FromUserHex<uint256>(str); }
200 constexpr uint256() = default;
201 consteval explicit uint256(std::string_view hex_str) : base_blob<256>(hex_str) {}
202 constexpr explicit uint256(uint8_t v) : base_blob<256>(v) {}
203 constexpr explicit uint256(std::span<const unsigned char> vch) : base_blob<256>(vch) {}
204 static const uint256 ZERO;
205 static const uint256 ONE;
206};
207
208#endif // BITCOIN_UINT256_H
Template base class for fixed-sized opaque blobs.
Definition: uint256.h:26
constexpr base_blob(uint8_t v)
Definition: uint256.h:38
constexpr base_blob(std::span< const unsigned char > vch)
Definition: uint256.h:40
constexpr bool IsNull() const
Definition: uint256.h:48
constexpr unsigned char * data()
Definition: uint256.h:99
consteval base_blob(std::string_view hex_str)
Definition: uint256.h:125
constexpr const unsigned char * begin() const
Definition: uint256.h:104
friend constexpr bool operator!=(const base_blob &a, const base_blob &b)
Definition: uint256.h:67
constexpr unsigned char * end()
Definition: uint256.h:102
static constexpr int WIDTH
Definition: uint256.h:28
static constexpr unsigned int size()
Definition: uint256.h:107
friend constexpr bool operator<(const base_blob &a, const base_blob &b)
Definition: uint256.h:68
constexpr uint64_t GetUint64(int pos) const
Definition: uint256.h:109
void Unserialize(Stream &s)
Definition: uint256.h:118
std::string ToString() const
Definition: uint256.cpp:21
friend constexpr bool operator==(const base_blob &a, const base_blob &b)
Definition: uint256.h:66
constexpr const unsigned char * end() const
Definition: uint256.h:105
constexpr int Compare(const base_blob &other) const
Lexicographic ordering.
Definition: uint256.h:64
constexpr unsigned char * begin()
Definition: uint256.h:101
void Serialize(Stream &s) const
Definition: uint256.h:112
constexpr void SetNull()
Definition: uint256.h:55
std::string GetHex() const
Definition: uint256.cpp:11
constexpr const unsigned char * data() const
Definition: uint256.h:98
std::array< uint8_t, WIDTH > m_data
Definition: uint256.h:30
constexpr base_blob()
Definition: uint256.h:35
160-bit opaque blob.
Definition: uint256.h:184
constexpr uint160(std::span< const unsigned char > vch)
Definition: uint256.h:188
static std::optional< uint160 > FromHex(std::string_view str)
Definition: uint256.h:186
constexpr uint160()=default
256-bit opaque blob.
Definition: uint256.h:196
static std::optional< uint256 > FromUserHex(std::string_view str)
Definition: uint256.h:199
constexpr uint256()=default
static const uint256 ONE
Definition: uint256.h:205
static const uint256 ZERO
Definition: uint256.h:204
constexpr uint256(std::span< const unsigned char > vch)
Definition: uint256.h:203
static std::optional< uint256 > FromHex(std::string_view str)
Definition: uint256.h:198
constexpr uint256(uint8_t v)
Definition: uint256.h:202
consteval uint256(std::string_view hex_str)
Definition: uint256.h:201
uint64_t ReadLE64(const B *ptr)
Definition: common.h:35
signed char HexDigit(char c)
Definition: hex_base.cpp:63
std::optional< uintN_t > FromHex(std::string_view str)
Writes the hex string (in reverse byte order) into a new uintN_t object and only returns a value iff ...
Definition: uint256.h:143
std::optional< uintN_t > FromUserHex(std::string_view input)
Like FromHex(std::string_view str), but allows an "0x" prefix and pads the input with leading zeroes ...
Definition: uint256.h:167
consteval uint8_t ConstevalHexDigit(const char c)
consteval version of HexDigit() without the lookup table.
Definition: strencodings.h:372
std::string_view RemovePrefixView(std::string_view str, std::string_view prefix)
Definition: string.h:169
auto MakeWritableByteSpan(V &&v) noexcept
Definition: span.h:89
bool IsHex(std::string_view str)
assert(!tx.IsCoinBase())