Commit 180e6772 authored by Kenton Varda's avatar Kenton Varda

Add a way to get the future header table reference from a builder.

parent cdd93693
...@@ -196,6 +196,14 @@ public: ...@@ -196,6 +196,14 @@ public:
HttpHeaderId add(kj::StringPtr name); HttpHeaderId add(kj::StringPtr name);
Own<HttpHeaderTable> build(); Own<HttpHeaderTable> build();
HttpHeaderTable& getFutureTable();
// Get the still-unbuilt header table. You cannot actually use it until build() has been
// called.
//
// This method exists to help when building a shared header table -- the Builder may be passed
// to several components, each of which will register the headers they need and get a reference
// to the future table.
private: private:
kj::Own<HttpHeaderTable> table; kj::Own<HttpHeaderTable> table;
}; };
...@@ -590,6 +598,7 @@ inline void HttpHeaderId::requireFrom(HttpHeaderTable& table) const { ...@@ -590,6 +598,7 @@ inline void HttpHeaderId::requireFrom(HttpHeaderTable& table) const {
} }
inline kj::Own<HttpHeaderTable> HttpHeaderTable::Builder::build() { return kj::mv(table); } inline kj::Own<HttpHeaderTable> HttpHeaderTable::Builder::build() { return kj::mv(table); }
inline HttpHeaderTable& HttpHeaderTable::Builder::getFutureTable() { return *table; }
inline uint HttpHeaderTable::idCount() { return namesById.size(); } inline uint HttpHeaderTable::idCount() { return namesById.size(); }
......
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