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