Commit 33358946 authored by Kenton Varda's avatar Kenton Varda

Fix various builds.

parent 5480b2aa
...@@ -325,7 +325,7 @@ private: ...@@ -325,7 +325,7 @@ private:
MessageBuilder* message; MessageBuilder* message;
ReadLimiter dummyLimiter; ReadLimiter dummyLimiter;
class LocalCapTable: public CapTableBuilder { class LocalCapTable final: public CapTableBuilder {
#if !CAPNP_LITE #if !CAPNP_LITE
public: public:
kj::Maybe<kj::Own<ClientHook>> extractCap(uint index) override; kj::Maybe<kj::Own<ClientHook>> extractCap(uint index) override;
......
...@@ -39,6 +39,7 @@ namespace capnp { ...@@ -39,6 +39,7 @@ namespace capnp {
namespace _ { // private namespace _ { // private
class ReaderArena; class ReaderArena;
class BuilderArena; class BuilderArena;
struct CloneImpl;
} }
class StructSchema; class StructSchema;
...@@ -258,8 +259,10 @@ private: ...@@ -258,8 +259,10 @@ private:
kj::Own<_::CapTableBuilder> releaseBuiltinCapTable(); kj::Own<_::CapTableBuilder> releaseBuiltinCapTable();
// Hack for clone() to extract the cap table. // Hack for clone() to extract the cap table.
template <typename Reader, typename> friend struct _::CloneImpl;
friend kj::Own<kj::Decay<Reader>> clone(Reader&& reader); // We can't declare clone() as a friend directly because old versions of GCC incorrectly demand
// that the first declaration (even if it is a friend declaration) specify the default type args,
// whereas correct compilers do not permit default type args to be specified on a friend decl.
}; };
template <typename RootType> template <typename RootType>
...@@ -516,6 +519,14 @@ static typename Type::Reader defaultValue() { ...@@ -516,6 +519,14 @@ static typename Type::Reader defaultValue() {
return typename Type::Reader(_::StructReader()); return typename Type::Reader(_::StructReader());
} }
namespace _ {
struct CloneImpl {
static inline kj::Own<_::CapTableBuilder> releaseBuiltinCapTable(MessageBuilder& message) {
return message.releaseBuiltinCapTable();
}
};
};
template <typename Reader, typename> template <typename Reader, typename>
kj::Own<kj::Decay<Reader>> clone(Reader&& reader) { kj::Own<kj::Decay<Reader>> clone(Reader&& reader) {
auto size = reader.totalSize(); auto size = reader.totalSize();
...@@ -529,7 +540,7 @@ kj::Own<kj::Decay<Reader>> clone(Reader&& reader) { ...@@ -529,7 +540,7 @@ kj::Own<kj::Decay<Reader>> clone(Reader&& reader) {
FlatMessageBuilder builder(buffer); FlatMessageBuilder builder(buffer);
builder.setRoot(kj::fwd<Reader>(reader)); builder.setRoot(kj::fwd<Reader>(reader));
builder.requireFilled(); builder.requireFilled();
auto capTable = builder.releaseBuiltinCapTable(); auto capTable = _::CloneImpl::releaseBuiltinCapTable(builder);
AnyPointer::Reader raw(_::PointerReader::getRootUnchecked(buffer.begin()).imbue(capTable)); AnyPointer::Reader raw(_::PointerReader::getRootUnchecked(buffer.begin()).imbue(capTable));
return kj::attachVal(raw.getAs<FromReader<Reader>>(), kj::mv(buffer), kj::mv(capTable)); return kj::attachVal(raw.getAs<FromReader<Reader>>(), kj::mv(buffer), kj::mv(capTable));
} }
......
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