From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../rust/neqo-http3/src/qpack_decoder_receiver.rs | 44 ++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 third_party/rust/neqo-http3/src/qpack_decoder_receiver.rs (limited to 'third_party/rust/neqo-http3/src/qpack_decoder_receiver.rs') diff --git a/third_party/rust/neqo-http3/src/qpack_decoder_receiver.rs b/third_party/rust/neqo-http3/src/qpack_decoder_receiver.rs new file mode 100644 index 0000000000..3cdfdf74cd --- /dev/null +++ b/third_party/rust/neqo-http3/src/qpack_decoder_receiver.rs @@ -0,0 +1,44 @@ +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use crate::{CloseType, Error, Http3StreamType, ReceiveOutput, RecvStream, Res, Stream}; +use neqo_qpack::QPackDecoder; +use neqo_transport::{Connection, StreamId}; +use std::cell::RefCell; +use std::rc::Rc; + +#[derive(Debug)] +pub(crate) struct DecoderRecvStream { + stream_id: StreamId, + decoder: Rc>, +} + +impl DecoderRecvStream { + pub fn new(stream_id: StreamId, decoder: Rc>) -> Self { + Self { stream_id, decoder } + } +} + +impl Stream for DecoderRecvStream { + fn stream_type(&self) -> Http3StreamType { + Http3StreamType::Decoder + } +} + +impl RecvStream for DecoderRecvStream { + fn reset(&mut self, _close_type: CloseType) -> Res<()> { + Err(Error::HttpClosedCriticalStream) + } + + fn receive(&mut self, conn: &mut Connection) -> Res<(ReceiveOutput, bool)> { + Ok(( + ReceiveOutput::UnblockedStreams( + self.decoder.borrow_mut().receive(conn, self.stream_id)?, + ), + false, + )) + } +} -- cgit v1.2.3