JsonStream

Struct JsonStream 

Source
pub struct JsonStream<C, B, T> { /* private fields */ }
Expand description

An asynchronous JSON streamer for HTTP network requests.

Implementations§

Source§

impl<C, B, T, D, E> JsonStream<C, B, T>
where C: Future<Output = Result<D, E>> + Unpin, D: Into<Response<B>>, B: Body + Unpin, T: DeserializeOwned, E: Error + 'static, B::Error: Error + 'static,

Source

pub fn request(call: C, part: JsonPart) -> Self

Creates a new JSON streamer from the given HTTP response future.

Completes the request and streams the body for status 2XX responses.

Use JsonStream::process instead to customize response handling.

Source§

impl<B, T> JsonStream<Ready<Result<Response<B>, Infallible>>, B, T>
where B: Body + Unpin, T: DeserializeOwned, B::Error: Error + 'static,

Source

pub fn process(resp: impl Into<Response<B>>, part: JsonPart) -> Self

Creates a new JSON streamer from the given HTTP response.

Trait Implementations§

Source§

impl<C, B, T> Debug for JsonStream<C, B, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<C, B, T, D, E> FusedStream for JsonStream<C, B, T>
where C: Future<Output = Result<D, E>> + Unpin, D: Into<Response<B>>, B: Body + Unpin, T: DeserializeOwned, E: Error + 'static, B::Error: Error + 'static,

Source§

fn is_terminated(&self) -> bool

Returns true if the stream should no longer be polled.
Source§

impl<C, B, T, D, E> Stream for JsonStream<C, B, T>
where C: Future<Output = Result<D, E>> + Unpin, D: Into<Response<B>>, B: Body + Unpin, T: DeserializeOwned, E: Error + 'static, B::Error: Error + 'static,

Source§

type Item = Result<T, Error>

Values yielded by the stream.
Source§

fn poll_next( self: Pin<&mut Self>, cx: &mut Context<'_>, ) -> Poll<Option<Self::Item>>

Attempt to pull out the next value of this stream, registering the current task for wakeup if the value is not yet available, and returning None if the stream is exhausted. Read more
Source§

fn size_hint(&self) -> (usize, Option<usize>)

Returns the bounds on the remaining length of the stream. Read more

Auto Trait Implementations§

§

impl<C, B, T> Freeze for JsonStream<C, B, T>
where C: Freeze, B: Freeze,

§

impl<C, B, T> !RefUnwindSafe for JsonStream<C, B, T>

§

impl<C, B, T> Send for JsonStream<C, B, T>

§

impl<C, B, T> Sync for JsonStream<C, B, T>

§

impl<C, B, T> Unpin for JsonStream<C, B, T>

§

impl<C, B, T> !UnwindSafe for JsonStream<C, B, T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T, E> TryStream for S
where S: Stream<Item = Result<T, E>> + ?Sized,

Source§

type Ok = T

The type of successful values yielded by this future
Source§

type Error = E

The type of failures yielded by this future
Source§

fn try_poll_next( self: Pin<&mut S>, cx: &mut Context<'_>, ) -> Poll<Option<Result<<S as TryStream>::Ok, <S as TryStream>::Error>>>

Poll this TryStream as if it were a Stream. Read more