Commit 8b0489d8 authored by Kenton Varda's avatar Kenton Varda

Make non-CAPNP_DEBUG_TYPES builds work again.

parent 093fac4a
...@@ -407,6 +407,7 @@ using kj::ThrowOverflow; ...@@ -407,6 +407,7 @@ using kj::ThrowOverflow;
using kj::assumeBits; using kj::assumeBits;
using kj::assumeMax; using kj::assumeMax;
using kj::subtractChecked; using kj::subtractChecked;
using kj::trySubtract;
template <typename T, typename U> template <typename T, typename U>
inline constexpr U* operator+(U* ptr, kj::Quantity<T, U> offset) { inline constexpr U* operator+(U* ptr, kj::Quantity<T, U> offset) {
...@@ -530,7 +531,183 @@ inline constexpr kj::ArrayPtr<U> arrayPtr(U* ptr, kj::Quantity<T, U> size) { ...@@ -530,7 +531,183 @@ inline constexpr kj::ArrayPtr<U> arrayPtr(U* ptr, kj::Quantity<T, U> size) {
#else #else
#error TODO template <uint width, typename T = uint>
using BitCountN = T;
template <uint width, typename T = uint>
using ByteCountN = T;
template <uint width, typename T = uint>
using WordCountN = T;
template <uint width, typename T = uint>
using ElementCountN = T;
template <uint width, typename T = uint>
using WirePointerCountN = T;
// XXX
typedef BitCountN<8, uint8_t> BitCount8;
typedef BitCountN<16, uint16_t> BitCount16;
typedef BitCountN<32, uint32_t> BitCount32;
typedef BitCountN<64, uint64_t> BitCount64;
typedef BitCountN<sizeof(uint) * 8, uint> BitCount;
typedef ByteCountN<8, uint8_t> ByteCount8;
typedef ByteCountN<16, uint16_t> ByteCount16;
typedef ByteCountN<32, uint32_t> ByteCount32;
typedef ByteCountN<64, uint64_t> ByteCount64;
typedef ByteCountN<sizeof(uint) * 8, uint> ByteCount;
typedef WordCountN<8, uint8_t> WordCount8;
typedef WordCountN<16, uint16_t> WordCount16;
typedef WordCountN<32, uint32_t> WordCount32;
typedef WordCountN<64, uint64_t> WordCount64;
typedef WordCountN<sizeof(uint) * 8, uint> WordCount;
typedef ElementCountN<8, uint8_t> ElementCount8;
typedef ElementCountN<16, uint16_t> ElementCount16;
typedef ElementCountN<32, uint32_t> ElementCount32;
typedef ElementCountN<64, uint64_t> ElementCount64;
typedef ElementCountN<sizeof(uint) * 8, uint> ElementCount;
typedef WirePointerCountN<8, uint8_t> WirePointerCount8;
typedef WirePointerCountN<16, uint16_t> WirePointerCount16;
typedef WirePointerCountN<32, uint32_t> WirePointerCount32;
typedef WirePointerCountN<64, uint64_t> WirePointerCount64;
typedef WirePointerCountN<sizeof(uint) * 8, uint> WirePointerCount;
template <uint width>
using BitsPerElementN = decltype(BitCountN<width>() / ElementCountN<width>());
template <uint width>
using BytesPerElementN = decltype(ByteCountN<width>() / ElementCountN<width>());
template <uint width>
using WordsPerElementN = decltype(WordCountN<width>() / ElementCountN<width>());
template <uint width>
using PointersPerElementN = decltype(WirePointerCountN<width>() / ElementCountN<width>());
using kj::ThrowOverflow;
// YYY
template <uint i> inline constexpr uint guarded() { return i; }
template <typename T> inline constexpr T guarded(T i) { return i; }
template <typename T> inline constexpr T unguard(T i) { return i; }
template <typename T, typename U> inline constexpr T unguardAs(U i) { return i; }
template <uint64_t requestedMax, typename T> inline constexpr uint unguardMax(T i) { return i; }
template <uint bits, typename T> inline constexpr uint unguardMaxBits(T i) { return i; }
template <uint newMax, typename T, typename ErrorFunc>
inline constexpr T assertMax(T value, ErrorFunc&& func) {
if (KJ_UNLIKELY(value > newMax)) func();
return value;
}
template <typename T, typename ErrorFunc>
inline constexpr T assertMax(uint newMax, T value, ErrorFunc&& func) {
if (KJ_UNLIKELY(value > newMax)) func();
return value;
}
template <uint bits, typename T, typename ErrorFunc = ThrowOverflow>
inline constexpr T assertMaxBits(T value, ErrorFunc&& func = ErrorFunc()) {
if (KJ_UNLIKELY(value > kj::maxValueForBits<bits>())) func();
return value;
}
template <typename T, typename ErrorFunc = ThrowOverflow>
inline constexpr T assertMaxBits(uint bits, T value, ErrorFunc&& func = ErrorFunc()) {
if (KJ_UNLIKELY(value > (1ull << bits) - 1)) func();
return value;
}
template <typename T, typename U> inline constexpr T upgradeGuard(U i) { return i; }
template <uint bits, typename T> inline constexpr T assumeBits(T i) { return i; }
template <uint64_t max, typename T> inline constexpr T assumeMax(T i) { return i; }
template <typename T, typename U, typename ErrorFunc = ThrowOverflow>
inline auto subtractChecked(T a, U b, ErrorFunc&& errorFunc = ErrorFunc())
-> decltype(a - b) {
if (b > a) errorFunc();
return a - b;
}
template <typename T, typename U>
inline auto trySubtract(T a, U b) -> kj::Maybe<decltype(a - b)> {
if (b > a) {
return nullptr;
} else {
return a - b;
}
}
constexpr uint BITS = 1;
constexpr uint BYTES = 1;
constexpr uint WORDS = 1;
constexpr uint ELEMENTS = 1;
constexpr uint POINTERS = 1;
constexpr uint ZERO = 0;
constexpr uint ONE = 1;
// GCC 4.7 actually gives unused warnings on these constants in opt mode...
constexpr uint BITS_PER_BYTE KJ_UNUSED = 8;
constexpr uint BITS_PER_WORD KJ_UNUSED = 64;
constexpr uint BYTES_PER_WORD KJ_UNUSED = 8;
constexpr uint BITS_PER_POINTER KJ_UNUSED = 64;
constexpr uint BYTES_PER_POINTER KJ_UNUSED = 8;
constexpr uint WORDS_PER_POINTER KJ_UNUSED = 1;
// XXX
constexpr uint POINTER_SIZE_IN_WORDS = ONE * POINTERS * WORDS_PER_POINTER;
constexpr uint SEGMENT_WORD_COUNT_BITS = 29; // Number of words in a segment.
constexpr uint LIST_ELEMENT_COUNT_BITS = 29; // Number of elements in a list.
constexpr uint STRUCT_DATA_WORD_COUNT_BITS = 16; // Number of words in a Struct data section.
constexpr uint STRUCT_POINTER_COUNT_BITS = 16; // Number of pointers in a Struct pointer section.
constexpr uint BLOB_SIZE_BITS = 29; // Number of bytes in a blob.
typedef WordCountN<SEGMENT_WORD_COUNT_BITS> SegmentWordCount;
typedef ElementCountN<LIST_ELEMENT_COUNT_BITS> ListElementCount;
typedef WordCountN<STRUCT_DATA_WORD_COUNT_BITS, uint16_t> StructDataWordCount;
typedef WirePointerCountN<STRUCT_POINTER_COUNT_BITS, uint16_t> StructPointerCount;
typedef ByteCountN<BLOB_SIZE_BITS> BlobSize;
// YYY
constexpr auto MAX_SEGMENT_WORDS = kj::maxValueForBits<SEGMENT_WORD_COUNT_BITS>();
constexpr auto MAX_LIST_ELEMENTS = kj::maxValueForBits<LIST_ELEMENT_COUNT_BITS>();
constexpr auto MAX_STUCT_DATA_WORDS = kj::maxValueForBits<STRUCT_DATA_WORD_COUNT_BITS>();
constexpr auto MAX_STRUCT_POINTER_COUNT = kj::maxValueForBits<STRUCT_POINTER_COUNT_BITS>();
typedef uint StructDataBitCount;
typedef uint StructDataOffset;
typedef uint StructPointerOffset;
inline StructDataOffset assumeDataOffset(uint32_t offset) { return offset; }
inline StructPointerOffset assumePointerOffset(uint32_t offset) { return offset; }
constexpr uint MAX_TEXT_SIZE = kj::maxValueForBits<BLOB_SIZE_BITS>() - 1;
typedef uint TextSize;
template <typename T>
inline KJ_CONSTEXPR() size_t bytesPerElement() { return sizeof(T); }
template <typename T>
inline KJ_CONSTEXPR() size_t bitsPerElement() { return sizeof(T) * 8; }
template <typename T>
inline constexpr ptrdiff_t intervalLength(const T* a, const T* b, uint) {
return b - a;
}
template <typename T, typename U>
inline constexpr kj::ArrayPtr<const U> arrayPtr(const U* ptr, T size) {
return kj::arrayPtr(ptr, size);
}
template <typename T, typename U>
inline constexpr kj::ArrayPtr<U> arrayPtr(U* ptr, T size) {
return kj::arrayPtr(ptr, size);
}
#endif #endif
......
This diff is collapsed.
This diff is collapsed.
This source diff could not be displayed because it is too large. You can view the blob instead.
This diff is collapsed.
...@@ -59,7 +59,11 @@ namespace _ { // private ...@@ -59,7 +59,11 @@ namespace _ { // private
#endif // !CAPNP_LITE #endif // !CAPNP_LITE
#if CAPNP_DEBUG_TYPES
#define G(n) guarded<n>() #define G(n) guarded<n>()
#else
#define G(n) n
#endif
// ======================================================================================= // =======================================================================================
...@@ -1766,7 +1770,7 @@ struct WireHelpers { ...@@ -1766,7 +1770,7 @@ struct WireHelpers {
if (value.elementSize == ElementSize::POINTER) { if (value.elementSize == ElementSize::POINTER) {
// List of pointers. // List of pointers.
ref->listRef.set(ElementSize::POINTER, value.elementCount); ref->listRef.set(ElementSize::POINTER, value.elementCount);
for (auto i: zeroTo(value.elementCount * (ONE * POINTERS / ELEMENTS))) { for (auto i: kj::zeroTo(value.elementCount * (ONE * POINTERS / ELEMENTS))) {
copyPointer(segment, capTable, reinterpret_cast<WirePointer*>(ptr) + i, copyPointer(segment, capTable, reinterpret_cast<WirePointer*>(ptr) + i,
value.segment, value.capTable, value.segment, value.capTable,
reinterpret_cast<const WirePointer*>(value.ptr) + i, reinterpret_cast<const WirePointer*>(value.ptr) + i,
...@@ -1807,7 +1811,7 @@ struct WireHelpers { ...@@ -1807,7 +1811,7 @@ struct WireHelpers {
auto newTotalSize = (dataSize + upgradeGuard<uint64_t>(ptrCount) * WORDS_PER_POINTER) auto newTotalSize = (dataSize + upgradeGuard<uint64_t>(ptrCount) * WORDS_PER_POINTER)
/ ELEMENTS * value.elementCount; / ELEMENTS * value.elementCount;
KJ_ASSERT(newTotalSize <= totalSize); // we've only removed data! KJ_ASSERT(newTotalSize <= totalSize); // we've only removed data!
totalSize = kj::assumeMax<kj::maxValueForBits<SEGMENT_WORD_COUNT_BITS>() - 1>(newTotalSize); totalSize = assumeMax<kj::maxValueForBits<SEGMENT_WORD_COUNT_BITS>() - 1>(newTotalSize);
} else { } else {
dataSize = declDataSize; dataSize = declDataSize;
ptrCount = declPointerCount; ptrCount = declPointerCount;
...@@ -2886,14 +2890,14 @@ bool StructReader::isCanonical(const word **readHead, ...@@ -2886,14 +2890,14 @@ bool StructReader::isCanonical(const word **readHead,
auto dataSize = this->getDataSectionSize() / BITS_PER_WORD; auto dataSize = this->getDataSectionSize() / BITS_PER_WORD;
// Mark whether the struct is properly truncated // Mark whether the struct is properly truncated
KJ_IF_MAYBE(diff, kj::trySubtract(dataSize, ONE * WORDS)) { KJ_IF_MAYBE(diff, trySubtract(dataSize, ONE * WORDS)) {
*dataTrunc = this->getDataField<uint64_t>(*diff / WORDS * ELEMENTS) != 0; *dataTrunc = this->getDataField<uint64_t>(*diff / WORDS * ELEMENTS) != 0;
} else { } else {
// Data segment empty. // Data segment empty.
*dataTrunc = true; *dataTrunc = true;
} }
KJ_IF_MAYBE(diff, kj::trySubtract(this->pointerCount, ONE * POINTERS)) { KJ_IF_MAYBE(diff, trySubtract(this->pointerCount, ONE * POINTERS)) {
*ptrTrunc = !this->getPointerField(*diff).isNull(); *ptrTrunc = !this->getPointerField(*diff).isNull();
} else { } else {
*ptrTrunc = true; *ptrTrunc = true;
......
This diff is collapsed.
...@@ -600,121 +600,121 @@ private: ...@@ -600,121 +600,121 @@ private:
inline ::capnp::rpc::twoparty::Side VatId::Reader::getSide() const { inline ::capnp::rpc::twoparty::Side VatId::Reader::getSide() const {
return _reader.getDataField< ::capnp::rpc::twoparty::Side>( return _reader.getDataField< ::capnp::rpc::twoparty::Side>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline ::capnp::rpc::twoparty::Side VatId::Builder::getSide() { inline ::capnp::rpc::twoparty::Side VatId::Builder::getSide() {
return _builder.getDataField< ::capnp::rpc::twoparty::Side>( return _builder.getDataField< ::capnp::rpc::twoparty::Side>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline void VatId::Builder::setSide( ::capnp::rpc::twoparty::Side value) { inline void VatId::Builder::setSide( ::capnp::rpc::twoparty::Side value) {
_builder.setDataField< ::capnp::rpc::twoparty::Side>( _builder.setDataField< ::capnp::rpc::twoparty::Side>(
::kj::guarded<0>() * ::capnp::ELEMENTS, value); ::capnp::guarded<0>() * ::capnp::ELEMENTS, value);
} }
inline ::uint32_t ProvisionId::Reader::getJoinId() const { inline ::uint32_t ProvisionId::Reader::getJoinId() const {
return _reader.getDataField< ::uint32_t>( return _reader.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline ::uint32_t ProvisionId::Builder::getJoinId() { inline ::uint32_t ProvisionId::Builder::getJoinId() {
return _builder.getDataField< ::uint32_t>( return _builder.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline void ProvisionId::Builder::setJoinId( ::uint32_t value) { inline void ProvisionId::Builder::setJoinId( ::uint32_t value) {
_builder.setDataField< ::uint32_t>( _builder.setDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS, value); ::capnp::guarded<0>() * ::capnp::ELEMENTS, value);
} }
inline ::uint32_t JoinKeyPart::Reader::getJoinId() const { inline ::uint32_t JoinKeyPart::Reader::getJoinId() const {
return _reader.getDataField< ::uint32_t>( return _reader.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline ::uint32_t JoinKeyPart::Builder::getJoinId() { inline ::uint32_t JoinKeyPart::Builder::getJoinId() {
return _builder.getDataField< ::uint32_t>( return _builder.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline void JoinKeyPart::Builder::setJoinId( ::uint32_t value) { inline void JoinKeyPart::Builder::setJoinId( ::uint32_t value) {
_builder.setDataField< ::uint32_t>( _builder.setDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS, value); ::capnp::guarded<0>() * ::capnp::ELEMENTS, value);
} }
inline ::uint16_t JoinKeyPart::Reader::getPartCount() const { inline ::uint16_t JoinKeyPart::Reader::getPartCount() const {
return _reader.getDataField< ::uint16_t>( return _reader.getDataField< ::uint16_t>(
::kj::guarded<2>() * ::capnp::ELEMENTS); ::capnp::guarded<2>() * ::capnp::ELEMENTS);
} }
inline ::uint16_t JoinKeyPart::Builder::getPartCount() { inline ::uint16_t JoinKeyPart::Builder::getPartCount() {
return _builder.getDataField< ::uint16_t>( return _builder.getDataField< ::uint16_t>(
::kj::guarded<2>() * ::capnp::ELEMENTS); ::capnp::guarded<2>() * ::capnp::ELEMENTS);
} }
inline void JoinKeyPart::Builder::setPartCount( ::uint16_t value) { inline void JoinKeyPart::Builder::setPartCount( ::uint16_t value) {
_builder.setDataField< ::uint16_t>( _builder.setDataField< ::uint16_t>(
::kj::guarded<2>() * ::capnp::ELEMENTS, value); ::capnp::guarded<2>() * ::capnp::ELEMENTS, value);
} }
inline ::uint16_t JoinKeyPart::Reader::getPartNum() const { inline ::uint16_t JoinKeyPart::Reader::getPartNum() const {
return _reader.getDataField< ::uint16_t>( return _reader.getDataField< ::uint16_t>(
::kj::guarded<3>() * ::capnp::ELEMENTS); ::capnp::guarded<3>() * ::capnp::ELEMENTS);
} }
inline ::uint16_t JoinKeyPart::Builder::getPartNum() { inline ::uint16_t JoinKeyPart::Builder::getPartNum() {
return _builder.getDataField< ::uint16_t>( return _builder.getDataField< ::uint16_t>(
::kj::guarded<3>() * ::capnp::ELEMENTS); ::capnp::guarded<3>() * ::capnp::ELEMENTS);
} }
inline void JoinKeyPart::Builder::setPartNum( ::uint16_t value) { inline void JoinKeyPart::Builder::setPartNum( ::uint16_t value) {
_builder.setDataField< ::uint16_t>( _builder.setDataField< ::uint16_t>(
::kj::guarded<3>() * ::capnp::ELEMENTS, value); ::capnp::guarded<3>() * ::capnp::ELEMENTS, value);
} }
inline ::uint32_t JoinResult::Reader::getJoinId() const { inline ::uint32_t JoinResult::Reader::getJoinId() const {
return _reader.getDataField< ::uint32_t>( return _reader.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline ::uint32_t JoinResult::Builder::getJoinId() { inline ::uint32_t JoinResult::Builder::getJoinId() {
return _builder.getDataField< ::uint32_t>( return _builder.getDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS); ::capnp::guarded<0>() * ::capnp::ELEMENTS);
} }
inline void JoinResult::Builder::setJoinId( ::uint32_t value) { inline void JoinResult::Builder::setJoinId( ::uint32_t value) {
_builder.setDataField< ::uint32_t>( _builder.setDataField< ::uint32_t>(
::kj::guarded<0>() * ::capnp::ELEMENTS, value); ::capnp::guarded<0>() * ::capnp::ELEMENTS, value);
} }
inline bool JoinResult::Reader::getSucceeded() const { inline bool JoinResult::Reader::getSucceeded() const {
return _reader.getDataField<bool>( return _reader.getDataField<bool>(
::kj::guarded<32>() * ::capnp::ELEMENTS); ::capnp::guarded<32>() * ::capnp::ELEMENTS);
} }
inline bool JoinResult::Builder::getSucceeded() { inline bool JoinResult::Builder::getSucceeded() {
return _builder.getDataField<bool>( return _builder.getDataField<bool>(
::kj::guarded<32>() * ::capnp::ELEMENTS); ::capnp::guarded<32>() * ::capnp::ELEMENTS);
} }
inline void JoinResult::Builder::setSucceeded(bool value) { inline void JoinResult::Builder::setSucceeded(bool value) {
_builder.setDataField<bool>( _builder.setDataField<bool>(
::kj::guarded<32>() * ::capnp::ELEMENTS, value); ::capnp::guarded<32>() * ::capnp::ELEMENTS, value);
} }
inline bool JoinResult::Reader::hasCap() const { inline bool JoinResult::Reader::hasCap() const {
return !_reader.getPointerField( return !_reader.getPointerField(
::kj::guarded<0>() * ::capnp::POINTERS).isNull(); ::capnp::guarded<0>() * ::capnp::POINTERS).isNull();
} }
inline bool JoinResult::Builder::hasCap() { inline bool JoinResult::Builder::hasCap() {
return !_builder.getPointerField( return !_builder.getPointerField(
::kj::guarded<0>() * ::capnp::POINTERS).isNull(); ::capnp::guarded<0>() * ::capnp::POINTERS).isNull();
} }
inline ::capnp::AnyPointer::Reader JoinResult::Reader::getCap() const { inline ::capnp::AnyPointer::Reader JoinResult::Reader::getCap() const {
return ::capnp::AnyPointer::Reader(_reader.getPointerField( return ::capnp::AnyPointer::Reader(_reader.getPointerField(
::kj::guarded<0>() * ::capnp::POINTERS)); ::capnp::guarded<0>() * ::capnp::POINTERS));
} }
inline ::capnp::AnyPointer::Builder JoinResult::Builder::getCap() { inline ::capnp::AnyPointer::Builder JoinResult::Builder::getCap() {
return ::capnp::AnyPointer::Builder(_builder.getPointerField( return ::capnp::AnyPointer::Builder(_builder.getPointerField(
::kj::guarded<0>() * ::capnp::POINTERS)); ::capnp::guarded<0>() * ::capnp::POINTERS));
} }
inline ::capnp::AnyPointer::Builder JoinResult::Builder::initCap() { inline ::capnp::AnyPointer::Builder JoinResult::Builder::initCap() {
auto result = ::capnp::AnyPointer::Builder(_builder.getPointerField( auto result = ::capnp::AnyPointer::Builder(_builder.getPointerField(
::kj::guarded<0>() * ::capnp::POINTERS)); ::capnp::guarded<0>() * ::capnp::POINTERS));
result.clear(); result.clear();
return result; return result;
} }
......
This source diff could not be displayed because it is too large. You can view the blob instead.
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment