Re-land: C++ readability review
[chromium-blink-merge.git] / net / spdy / hpack_output_stream.h
blobc607e492efe1b55cd8918d24ed9551b4aa656252
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_SPDY_HPACK_OUTPUT_STREAM_H_
6 #define NET_SPDY_HPACK_OUTPUT_STREAM_H_
8 #include <map>
9 #include <string>
11 #include "base/basictypes.h"
12 #include "base/macros.h"
13 #include "base/strings/string_piece.h"
14 #include "net/base/net_export.h"
15 #include "net/spdy/hpack_constants.h"
17 // All section references below are to
18 // http://tools.ietf.org/html/draft-ietf-httpbis-header-compression-08
20 namespace net {
22 // An HpackOutputStream handles all the low-level details of encoding
23 // header fields.
24 class NET_EXPORT_PRIVATE HpackOutputStream {
25 public:
26 explicit HpackOutputStream();
27 ~HpackOutputStream();
29 // Appends the lower |bit_size| bits of |bits| to the internal buffer.
31 // |bit_size| must be > 0 and <= 8. |bits| must not have any bits
32 // set other than the lower |bit_size| bits.
33 void AppendBits(uint8 bits, size_t bit_size);
35 // Simply forwards to AppendBits(prefix.bits, prefix.bit-size).
36 void AppendPrefix(HpackPrefix prefix);
38 // Directly appends |buffer|.
39 void AppendBytes(base::StringPiece buffer);
41 // Appends the given integer using the representation described in
42 // 6.1. If the internal buffer ends on a byte boundary, the prefix
43 // length N is taken to be 8; otherwise, it is taken to be the
44 // number of bits to the next byte boundary.
46 // It is guaranteed that the internal buffer will end on a byte
47 // boundary after this function is called.
48 void AppendUint32(uint32 I);
50 // Swaps the interal buffer with |output|.
51 void TakeString(std::string* output);
53 private:
54 // The internal bit buffer.
55 std::string buffer_;
57 // If 0, the buffer ends on a byte boundary. If non-zero, the buffer
58 // ends on the most significant nth bit. Guaranteed to be < 8.
59 size_t bit_offset_;
61 DISALLOW_COPY_AND_ASSIGN(HpackOutputStream);
64 } // namespace net
66 #endif // NET_SPDY_HPACK_OUTPUT_STREAM_H_