| Index: net/http2/decoder/payload_decoders/unknown_payload_decoder.cc
|
| diff --git a/net/http2/decoder/payload_decoders/unknown_payload_decoder.cc b/net/http2/decoder/payload_decoders/unknown_payload_decoder.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ec020c1617ab17f8ae43667b44598f51c780a783
|
| --- /dev/null
|
| +++ b/net/http2/decoder/payload_decoders/unknown_payload_decoder.cc
|
| @@ -0,0 +1,55 @@
|
| +// 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.
|
| +
|
| +#include "net/http2/decoder/payload_decoders/unknown_payload_decoder.h"
|
| +
|
| +#include <stddef.h>
|
| +
|
| +#include "base/logging.h"
|
| +#include "net/http2/decoder/decode_buffer.h"
|
| +#include "net/http2/decoder/http2_frame_decoder_listener.h"
|
| +#include "net/http2/http2_constants.h"
|
| +#include "net/http2/http2_structures.h"
|
| +
|
| +namespace net {
|
| +
|
| +DecodeStatus UnknownPayloadDecoder::StartDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + const Http2FrameHeader& frame_header = state->frame_header();
|
| +
|
| + DVLOG(2) << "UnknownPayloadDecoder::StartDecodingPayload: " << frame_header;
|
| + DCHECK(!IsSupportedHttp2FrameType(frame_header.type)) << frame_header;
|
| + DCHECK_LE(db->Remaining(), frame_header.payload_length);
|
| +
|
| + state->InitializeRemainders();
|
| + state->listener()->OnUnknownStart(frame_header);
|
| + return ResumeDecodingPayload(state, db);
|
| +}
|
| +
|
| +DecodeStatus UnknownPayloadDecoder::ResumeDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + DVLOG(2) << "UnknownPayloadDecoder::ResumeDecodingPayload "
|
| + << "remaining_payload=" << state->remaining_payload()
|
| + << "; db->Remaining=" << db->Remaining();
|
| + DCHECK(!IsSupportedHttp2FrameType(state->frame_header().type))
|
| + << state->frame_header();
|
| + DCHECK_LE(state->remaining_payload(), state->frame_header().payload_length);
|
| + DCHECK_LE(db->Remaining(), state->remaining_payload());
|
| +
|
| + size_t avail = db->Remaining();
|
| + if (avail > 0) {
|
| + state->listener()->OnUnknownPayload(db->cursor(), avail);
|
| + db->AdvanceCursor(avail);
|
| + state->ConsumePayload(avail);
|
| + }
|
| + if (state->remaining_payload() == 0) {
|
| + state->listener()->OnUnknownEnd();
|
| + return DecodeStatus::kDecodeDone;
|
| + }
|
| + return DecodeStatus::kDecodeInProgress;
|
| +}
|
| +
|
| +} // namespace net
|
|
|