8#ifndef BITCOIN_COMPAT_ASSUMPTIONS_H
9#define BITCOIN_COMPAT_ASSUMPTIONS_H
22static_assert(std::numeric_limits<float>::is_iec559,
"IEEE 754 float assumed");
23static_assert(std::numeric_limits<double>::is_iec559,
24 "IEEE 754 double assumed");
29static_assert(
sizeof(float) == 4,
"32-bit float assumed");
30static_assert(
sizeof(double) == 8,
"64-bit double assumed");
35static_assert(
sizeof(short) == 2,
"16-bit short assumed");
36static_assert(
sizeof(int) == 4,
"32-bit int assumed");
37static_assert(
sizeof(unsigned) == 4,
"32-bit unsigned assumed");
41static_assert(CHAR_BIT == 8,
"8-bit bytes assumed");
52static_assert(std::is_same<uint8_t, unsigned char>::value,
53 "uint8_t is an alias of unsigned char");
59static_assert(
sizeof(size_t) == 4 ||
sizeof(
size_t) == 8,
60 "size_t assumed to be 32-bit or 64-bit");
61static_assert(
sizeof(size_t) ==
sizeof(
void *),
62 "Sizes of size_t and void* assumed to be equal");
79static_assert((int64_t(-1) >> 1) == int64_t(-1),
80 "Arithmetic right shift assumed");
86static_assert((int64_t(-10) & 0xffff) == 0xfff6,
"2-complement assumed");
91static_assert(std::numeric_limits<long long int>::max() ==
92 std::numeric_limits<int64_t>::max());
93static_assert(std::numeric_limits<long long int>::min() ==
94 std::numeric_limits<int64_t>::min());