| Index: net/http2/decoder/payload_decoders/rst_stream_payload_decoder.cc
|
| diff --git a/net/http2/decoder/payload_decoders/rst_stream_payload_decoder.cc b/net/http2/decoder/payload_decoders/rst_stream_payload_decoder.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e9d86fb7385d48b49668f85aa625e2a7165556ae
|
| --- /dev/null
|
| +++ b/net/http2/decoder/payload_decoders/rst_stream_payload_decoder.cc
|
| @@ -0,0 +1,66 @@
|
| +// 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/rst_stream_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 RstStreamPayloadDecoder::StartDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + DVLOG(2) << "RstStreamPayloadDecoder::StartDecodingPayload: "
|
| + << state->frame_header();
|
| + DCHECK_EQ(Http2FrameType::RST_STREAM, state->frame_header().type);
|
| + DCHECK_LE(db->Remaining(), state->frame_header().payload_length);
|
| + // RST_STREAM has no flags.
|
| + DCHECK_EQ(0, state->frame_header().flags);
|
| + state->InitializeRemainders();
|
| + return HandleStatus(
|
| + state, state->StartDecodingStructureInPayload(&rst_stream_fields_, db));
|
| +}
|
| +
|
| +DecodeStatus RstStreamPayloadDecoder::ResumeDecodingPayload(
|
| + FrameDecoderState* state,
|
| + DecodeBuffer* db) {
|
| + DVLOG(2) << "RstStreamPayloadDecoder::ResumeDecodingPayload"
|
| + << " remaining_payload=" << state->remaining_payload()
|
| + << " db->Remaining=" << db->Remaining();
|
| + DCHECK_EQ(Http2FrameType::RST_STREAM, state->frame_header().type);
|
| + DCHECK_LE(db->Remaining(), state->frame_header().payload_length);
|
| + return HandleStatus(
|
| + state, state->ResumeDecodingStructureInPayload(&rst_stream_fields_, db));
|
| +}
|
| +
|
| +DecodeStatus RstStreamPayloadDecoder::HandleStatus(FrameDecoderState* state,
|
| + DecodeStatus status) {
|
| + DVLOG(2) << "HandleStatus: status=" << status
|
| + << "; remaining_payload=" << state->remaining_payload();
|
| + if (status == DecodeStatus::kDecodeDone) {
|
| + if (state->remaining_payload() == 0) {
|
| + state->listener()->OnRstStream(state->frame_header(),
|
| + rst_stream_fields_.error_code);
|
| + 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 by the FrameDecoderState.
|
| + 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
|
|
|