| Index: net/http2/decoder/payload_decoders/priority_payload_decoder.cc
|
| diff --git a/net/http2/decoder/payload_decoders/priority_payload_decoder.cc b/net/http2/decoder/payload_decoders/priority_payload_decoder.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..51ae80b9808c4be0dba7144851db3ae386f494d3
|
| --- /dev/null
|
| +++ b/net/http2/decoder/payload_decoders/priority_payload_decoder.cc
|
| @@ -0,0 +1,64 @@
|
| +// 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/priority_payload_decoder.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 PriorityPayloadDecoder::StartDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + DVLOG(2) << "PriorityPayloadDecoder::StartDecodingPayload: "
|
| + << state->frame_header();
|
| + DCHECK_EQ(Http2FrameType::PRIORITY, state->frame_header().type);
|
| + DCHECK_LE(db->Remaining(), state->frame_header().payload_length);
|
| + // PRIORITY frames have no flags.
|
| + DCHECK_EQ(0, state->frame_header().flags);
|
| + state->InitializeRemainders();
|
| + return HandleStatus(
|
| + state, state->StartDecodingStructureInPayload(&priority_fields_, db));
|
| +}
|
| +
|
| +DecodeStatus PriorityPayloadDecoder::ResumeDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + DVLOG(2) << "PriorityPayloadDecoder::ResumeDecodingPayload"
|
| + << " remaining_payload=" << state->remaining_payload()
|
| + << " db->Remaining=" << db->Remaining();
|
| + DCHECK_EQ(Http2FrameType::PRIORITY, state->frame_header().type);
|
| + DCHECK_LE(db->Remaining(), state->frame_header().payload_length);
|
| + return HandleStatus(
|
| + state, state->ResumeDecodingStructureInPayload(&priority_fields_, db));
|
| +}
|
| +
|
| +DecodeStatus PriorityPayloadDecoder::HandleStatus(FrameDecoderState* state,
|
| + DecodeStatus status) {
|
| + if (status == DecodeStatus::kDecodeDone) {
|
| + if (state->remaining_payload() == 0) {
|
| + state->listener()->OnPriorityFrame(state->frame_header(),
|
| + priority_fields_);
|
| + return DecodeStatus::kDecodeDone;
|
| + }
|
| + // Payload is too long.
|
| + return state->ReportFrameSizeError();
|
| + }
|
| + // Not done decoding the structure. Either we've got more payload to decode,
|
| + // or we've run out because the payload is too short, in which case
|
| + // OnFrameSizeError will have already been called.
|
| + DCHECK(
|
| + (status == DecodeStatus::kDecodeInProgress &&
|
| + state->remaining_payload() > 0) ||
|
| + (status == DecodeStatus::kDecodeError && state->remaining_payload() == 0))
|
| + << "\n status=" << status
|
| + << "; remaining_payload=" << state->remaining_payload();
|
| + return status;
|
| +}
|
| +
|
| +} // namespace net
|
|
|