1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
use crate::varint::VarInt;
//= https://www.rfc-editor.org/rfc/rfc9000#section-19.4
//# An endpoint uses a RESET_STREAM frame (type=0x04) to abruptly
//# terminate the sending part of a stream.
macro_rules! reset_stream_tag {
() => {
0x04u8
};
}
//= https://www.rfc-editor.org/rfc/rfc9000#section-19.4
//# RESET_STREAM Frame {
//# Type (i) = 0x04,
//# Stream ID (i),
//# Application Protocol Error Code (i),
//# Final Size (i),
//# }
//= https://www.rfc-editor.org/rfc/rfc9000#section-19.4
//# RESET_STREAM frames contain the following fields:
//#
//# Stream ID: A variable-length integer encoding of the stream ID of
//# the stream being terminated.
//#
//# Application Protocol Error Code: A variable-length integer
//# containing the application protocol error code (see Section 20.2)
//# that indicates why the stream is being closed.
//#
//# Final Size: A variable-length integer indicating the final size of
//# the stream by the RESET_STREAM sender, in units of bytes; see
//# Section 4.5.
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
pub struct ResetStream {
/// A variable-length integer encoding of the Stream ID of the
/// stream being terminated.
pub stream_id: VarInt,
/// A variable-length integer containing the application protocol
/// error code which indicates why the stream is being closed.
pub application_error_code: VarInt,
/// A variable-length integer indicating the final size of
/// the stream by the RESET_STREAM sender, in unit of bytes.
pub final_size: VarInt,
}
impl ResetStream {
pub const fn tag(&self) -> u8 {
reset_stream_tag!()
}
}
simple_frame_codec!(
ResetStream {
stream_id,
application_error_code,
final_size
},
reset_stream_tag!()
);