Commit 00c0cbfb authored by Kenton Varda's avatar Kenton Varda

Minor extensions to HttpHeaders.

- Add a `size()` method.
- Add a `forEach()` that enumerates tabled headers by ID, and only uses string names for non-tabled headers.
parent 63c34d47
...@@ -578,6 +578,16 @@ void HttpHeaders::clear() { ...@@ -578,6 +578,16 @@ void HttpHeaders::clear() {
unindexedHeaders.clear(); unindexedHeaders.clear();
} }
size_t HttpHeaders::size() const {
size_t result = unindexedHeaders.size();
for (auto i: kj::indices(indexedHeaders)) {
if (indexedHeaders[i] != nullptr) {
++result;
}
}
return result;
}
HttpHeaders HttpHeaders::clone() const { HttpHeaders HttpHeaders::clone() const {
HttpHeaders result(*table); HttpHeaders result(*table);
......
...@@ -117,6 +117,8 @@ public: ...@@ -117,6 +117,8 @@ public:
inline bool operator>=(const HttpHeaderId& other) const { return id >= other.id; } inline bool operator>=(const HttpHeaderId& other) const { return id >= other.id; }
inline size_t hashCode() const { return id; } inline size_t hashCode() const { return id; }
// Returned value is guaranteed to be small and never collide with other headers on the same
// table.
kj::StringPtr toString() const; kj::StringPtr toString() const;
...@@ -251,6 +253,9 @@ public: ...@@ -251,6 +253,9 @@ public:
HttpHeaders(HttpHeaders&&) = default; HttpHeaders(HttpHeaders&&) = default;
HttpHeaders& operator=(HttpHeaders&&) = default; HttpHeaders& operator=(HttpHeaders&&) = default;
size_t size() const;
// Returns the number of headers that forEach() would iterate over.
void clear(); void clear();
// Clears all contents, as if the object was freshly-allocated. However, calling this rather // Clears all contents, as if the object was freshly-allocated. However, calling this rather
// than actually re-allocating the object may avoid re-allocation of internal objects. // than actually re-allocating the object may avoid re-allocation of internal objects.
...@@ -277,6 +282,12 @@ public: ...@@ -277,6 +282,12 @@ public:
// Calls `func(name, value)` for each header in the set -- including headers that aren't mapped // Calls `func(name, value)` for each header in the set -- including headers that aren't mapped
// to IDs in the header table. Both inputs are of type kj::StringPtr. // to IDs in the header table. Both inputs are of type kj::StringPtr.
template <typename Func1, typename Func2>
void forEach(Func1&& func1, Func2&& func2) const;
// Calls `func1(id, value)` for each header in the set that has a registered HttpHeaderId, and
// `func2(name, value)` for each header that does not. All calls to func1() preceed all calls to
// func2().
void set(HttpHeaderId id, kj::StringPtr value); void set(HttpHeaderId id, kj::StringPtr value);
void set(HttpHeaderId id, kj::String&& value); void set(HttpHeaderId id, kj::String&& value);
// Sets a header value, overwriting the existing value. // Sets a header value, overwriting the existing value.
...@@ -957,4 +968,17 @@ inline void HttpHeaders::forEach(Func&& func) const { ...@@ -957,4 +968,17 @@ inline void HttpHeaders::forEach(Func&& func) const {
} }
} }
template <typename Func1, typename Func2>
inline void HttpHeaders::forEach(Func1&& func1, Func2&& func2) const {
for (auto i: kj::indices(indexedHeaders)) {
if (indexedHeaders[i] != nullptr) {
func1(HttpHeaderId(table, i), indexedHeaders[i]);
}
}
for (auto& header: unindexedHeaders) {
func2(header.name, header.value);
}
}
} // namespace kj } // namespace kj
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