| // Copyright 2014 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef NET_SPDY_HPACK_OUTPUT_STREAM_H_ |
| #define NET_SPDY_HPACK_OUTPUT_STREAM_H_ |
| |
| #include <map> |
| #include <string> |
| |
| #include "base/basictypes.h" |
| #include "base/macros.h" |
| #include "base/strings/string_piece.h" |
| #include "net/base/net_export.h" |
| #include "net/spdy/hpack_constants.h" // For HpackPrefix. |
| #include "net/spdy/hpack_encoding_context.h" |
| |
| // All section references below are to |
| // http://tools.ietf.org/html/draft-ietf-httpbis-header-compression-06 |
| |
| namespace net { |
| |
| // An HpackOutputStream handles all the low-level details of encoding |
| // header fields. |
| class NET_EXPORT_PRIVATE HpackOutputStream { |
| public: |
| // |max_string_literal_size| is the largest that any one string |
| // |literal (header name or header value) can be. |
| explicit HpackOutputStream(uint32 max_string_literal_size); |
| ~HpackOutputStream(); |
| |
| // Corresponds to 4.2. |
| void AppendIndexedHeader(uint32 index_or_zero); |
| |
| // Corresponds to 4.3.1 (second form). Returns whether or not the |
| // append was successful; if the append was unsuccessful, no other |
| // member function may be called. |
| bool AppendLiteralHeaderNoIndexingWithName(base::StringPiece name, |
| base::StringPiece value); |
| |
| // Moves the internal buffer to the given string and clears all |
| // internal state. |
| void TakeString(std::string* output); |
| |
| // Appends the lower |bit_size| bits of |bits| to the internal buffer. |
| // |
| // |bit_size| must be > 0 and <= 8. |bits| must not have any bits |
| // set other than the lower |bit_size| bits. |
| void AppendBits(uint8 bits, size_t bit_size); |
| |
| // Accessors for testing. |
| |
| void AppendBitsForTest(uint8 bits, size_t size) { |
| AppendBits(bits, size); |
| } |
| |
| void AppendUint32ForTest(uint32 I) { |
| AppendUint32(I); |
| } |
| |
| bool AppendStringLiteralForTest(base::StringPiece str) { |
| return AppendStringLiteral(str); |
| } |
| |
| private: |
| // Simply forwards to AppendBits(prefix.bits, prefix.bit-size). |
| void AppendPrefix(HpackPrefix prefix); |
| |
| // Appends the given integer using the representation described in |
| // 4.1.1. If the internal buffer ends on a byte boundary, the prefix |
| // length N is taken to be 8; otherwise, it is taken to be the |
| // number of bits to the next byte boundary. |
| // |
| // It is guaranteed that the internal buffer will end on a byte |
| // boundary after this function is called. |
| void AppendUint32(uint32 I); |
| |
| // Appends the given string using the representation described in |
| // 4.1.2. The internal buffer must end on a byte boundary, and it is |
| // guaranteed that the internal buffer will end on a byte boundary |
| // after this function is called. Returns whether or not the append |
| // was successful; if the append was unsuccessful, no other member |
| // function may be called. |
| bool AppendStringLiteral(base::StringPiece str); |
| |
| const uint32 max_string_literal_size_; |
| |
| // The internal bit buffer. |
| std::string buffer_; |
| |
| // If 0, the buffer ends on a byte boundary. If non-zero, the buffer |
| // ends on the most significant nth bit. Guaranteed to be < 8. |
| size_t bit_offset_; |
| |
| DISALLOW_COPY_AND_ASSIGN(HpackOutputStream); |
| }; |
| |
| } // namespace net |
| |
| #endif // NET_SPDY_HPACK_OUTPUT_STREAM_H_ |