| Index: net/spdy/hpack/hpack_decoder.h
|
| diff --git a/net/spdy/hpack/hpack_decoder.h b/net/spdy/hpack/hpack_decoder.h
|
| deleted file mode 100644
|
| index 6df4d1a3bd1871ce1b104d8716e5dda994e00ccb..0000000000000000000000000000000000000000
|
| --- a/net/spdy/hpack/hpack_decoder.h
|
| +++ /dev/null
|
| @@ -1,155 +0,0 @@
|
| -// 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_HPACK_DECODER_H_
|
| -#define NET_SPDY_HPACK_HPACK_DECODER_H_
|
| -
|
| -#include <stddef.h>
|
| -#include <stdint.h>
|
| -
|
| -#include <map>
|
| -#include <memory>
|
| -#include <vector>
|
| -
|
| -#include "base/macros.h"
|
| -#include "net/base/net_export.h"
|
| -#include "net/spdy/hpack/hpack_decoder_interface.h"
|
| -#include "net/spdy/hpack/hpack_header_table.h"
|
| -#include "net/spdy/hpack/hpack_input_stream.h"
|
| -#include "net/spdy/platform/api/spdy_string.h"
|
| -#include "net/spdy/platform/api/spdy_string_piece.h"
|
| -#include "net/spdy/spdy_headers_handler_interface.h"
|
| -#include "net/spdy/spdy_protocol.h"
|
| -
|
| -// An HpackDecoder decodes header sets as outlined in
|
| -// http://tools.ietf.org/html/rfc7541.
|
| -
|
| -namespace net {
|
| -
|
| -namespace test {
|
| -class HpackDecoderPeer;
|
| -} // namespace test
|
| -
|
| -class NET_EXPORT_PRIVATE HpackDecoder : public HpackDecoderInterface {
|
| - public:
|
| - friend class test::HpackDecoderPeer;
|
| -
|
| - HpackDecoder();
|
| - ~HpackDecoder() override;
|
| -
|
| - // Called upon sending a SETTINGS_HEADER_TABLE_SIZE value.
|
| - void ApplyHeaderTableSizeSetting(size_t size_setting) override;
|
| -
|
| - // If a SpdyHeadersHandlerInterface is provided, HpackDecoder will emit
|
| - // headers to it rather than accumulating them in a SpdyHeaderBlock.
|
| - void HandleControlFrameHeadersStart(
|
| - SpdyHeadersHandlerInterface* handler) override;
|
| -
|
| - // Called as headers data arrives. Returns false if an error occurred.
|
| - // TODO(jgraettinger): A future version of this method will incrementally
|
| - // parse and deliver headers via SpdyHeadersHandlerInterface. For now,
|
| - // header data is buffered until HandleControlFrameHeadersComplete().
|
| - bool HandleControlFrameHeadersData(const char* headers_data,
|
| - size_t headers_data_length) override;
|
| -
|
| - // Called after a headers block has been completely delivered via
|
| - // HandleControlFrameHeadersData(). Returns false if an error
|
| - // occurred. |compressed_len| if non-null will be set to the size
|
| - // of the encoded buffered block that was accumulated in
|
| - // HandleControlFrameHeadersData(), to support subsequent
|
| - // calculation of compression percentage. Clears |handler_|.
|
| - // TODO(jgraettinger): A
|
| - // future version of this method will simply deliver the Cookie
|
| - // header (which has been incrementally reconstructed) and notify
|
| - // the visitor that the block is finished.
|
| - bool HandleControlFrameHeadersComplete(size_t* compressed_len) override;
|
| -
|
| - // Accessor for the most recently decoded headers block. Valid until the next
|
| - // call to HandleControlFrameHeadersData().
|
| - // TODO(birenroy): Remove this method when all users of HpackDecoder specify
|
| - // a SpdyHeadersHandlerInterface.
|
| - const SpdyHeaderBlock& decoded_block() const override;
|
| -
|
| - void SetHeaderTableDebugVisitor(
|
| - std::unique_ptr<HpackHeaderTable::DebugVisitorInterface> visitor)
|
| - override;
|
| -
|
| - void set_max_decode_buffer_size_bytes(
|
| - size_t max_decode_buffer_size_bytes) override;
|
| -
|
| - size_t EstimateMemoryUsage() const override;
|
| -
|
| - private:
|
| - // Adds the header representation to |decoded_block_|, applying the
|
| - // following rules:
|
| - // - Multiple values of the Cookie header are joined, delmited by '; '.
|
| - // This reconstruction is required to properly handle Cookie crumbling
|
| - // (as per section 8.1.2.5 in RFC 7540).
|
| - // - Multiple values of other headers are joined and delimited by '\0'.
|
| - // Note that this may be too accomodating, as the sender's HTTP2 layer
|
| - // should have already joined and delimited these values.
|
| - //
|
| - // Returns false if a pseudo-header field follows a regular header one, which
|
| - // MUST be treated as malformed, as per sections 8.1.2.3. of the HTTP2
|
| - // specification (RFC 7540).
|
| - //
|
| - bool HandleHeaderRepresentation(SpdyStringPiece name, SpdyStringPiece value);
|
| -
|
| - // Handlers for decoding HPACK opcodes and header representations
|
| - // (or parts thereof). These methods return true on success and
|
| - // false on error.
|
| - bool DecodeNextOpcodeWrapper(HpackInputStream* input_stream);
|
| - bool DecodeNextOpcode(HpackInputStream* input_stream);
|
| - bool DecodeNextHeaderTableSizeUpdate(HpackInputStream* input_stream);
|
| - bool DecodeNextIndexedHeader(HpackInputStream* input_stream);
|
| - bool DecodeNextLiteralHeader(HpackInputStream* input_stream,
|
| - bool should_index);
|
| - bool DecodeNextName(HpackInputStream* input_stream,
|
| - SpdyStringPiece* next_name);
|
| - bool DecodeNextStringLiteral(HpackInputStream* input_stream,
|
| - bool is_header_key, // As distinct from a value.
|
| - SpdyStringPiece* output);
|
| -
|
| - HpackHeaderTable header_table_;
|
| -
|
| - // TODO(jgraettinger): Buffer for headers data, and storage for the last-
|
| - // processed headers block. Both will be removed with the switch to
|
| - // SpdyHeadersHandlerInterface.
|
| - SpdyString headers_block_buffer_;
|
| - SpdyHeaderBlock decoded_block_;
|
| -
|
| - // Scratch space for storing decoded literals.
|
| - SpdyString key_buffer_, value_buffer_;
|
| -
|
| - // If non-NULL, handles decoded headers.
|
| - SpdyHeadersHandlerInterface* handler_;
|
| - size_t total_header_bytes_;
|
| -
|
| - // How much encoded data this decoder is willing to buffer.
|
| - size_t max_decode_buffer_size_bytes_ = 32 * 1024; // 32 KB
|
| -
|
| - // Total bytes have been removed from headers_block_buffer_.
|
| - // Its value is updated during incremental decoding.
|
| - uint32_t total_parsed_bytes_;
|
| -
|
| - // Flag to keep track of having seen the header block start.
|
| - bool header_block_started_;
|
| -
|
| - // Number of dynamic table size updates seen at the start; a max of two
|
| - // are permitted.
|
| - uint8_t size_updates_seen_;
|
| -
|
| - // Are dynamic table size updates allowed at this point in decoding? True
|
| - // at the start, but not once we've seen a header entry.
|
| - bool size_updates_allowed_;
|
| -
|
| - // Saved value of --chromium_http2_flag_add_hpack_incremental_decode.
|
| - bool incremental_decode_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(HpackDecoder);
|
| -};
|
| -
|
| -} // namespace net
|
| -
|
| -#endif // NET_SPDY_HPACK_HPACK_DECODER_H_
|
|
|