blob: 79898becbef39d4d3ac331373408183d51a9bb0d [file] [log] [blame]
// Copyright 2016 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.
// Decodes the type of an HPACK entry, and the variable length integer whose
// prefix is in the low-order bits of the same byte, "below" the type bits.
// The integer represents an index into static or dynamic table, which may be
// zero, or is the new size limit of the dynamic table.
#include <cstdint>
#include "base/logging.h"
#include "net/third_party/quiche/src/http2/decoder/decode_buffer.h"
#include "net/third_party/quiche/src/http2/decoder/decode_status.h"
#include "net/third_party/quiche/src/http2/hpack/http2_hpack_constants.h"
#include "net/third_party/quiche/src/http2/hpack/varint/hpack_varint_decoder.h"
#include "net/third_party/quiche/src/http2/platform/api/http2_export.h"
#include "net/third_party/quiche/src/http2/platform/api/http2_string.h"
namespace http2 {
class HTTP2_EXPORT_PRIVATE HpackEntryTypeDecoder {
// Only call when the decode buffer has data (i.e. HpackEntryDecoder must
// not call until there is data).
DecodeStatus Start(DecodeBuffer* db);
// Only call Resume if the previous call (Start or Resume) returned
// DecodeStatus::kDecodeInProgress.
DecodeStatus Resume(DecodeBuffer* db) { return varint_decoder_.Resume(db); }
// Returns the decoded entry type. Only call if the preceding call to Start
// or Resume returned kDecodeDone.
HpackEntryType entry_type() const { return entry_type_; }
// Returns the decoded variable length integer. Only call if the
// preceding call to Start or Resume returned kDecodeDone.
uint64_t varint() const { return varint_decoder_.value(); }
Http2String DebugString() const;
HpackVarintDecoder varint_decoder_;
// This field is initialized just to keep ASAN happy about reading it
// from DebugString().
HpackEntryType entry_type_ = HpackEntryType::kIndexedHeader;
HTTP2_EXPORT_PRIVATE std::ostream& operator<<(std::ostream& out,
const HpackEntryTypeDecoder& v);
} // namespace http2