Enum hyper::http::h1::HttpReader
[−]
[src]
pub enum HttpReader<R> { SizedReader(R, u64), ChunkedReader(R, Option<u64>), EofReader(R), EmptyReader(R), }
Readers to handle different Transfer-Encodings.
If a message body does not include a Transfer-Encoding, it should include a Content-Length header.
Variants
SizedReader(R, u64)
A Reader used when a Content-Length header is passed with a positive integer.
ChunkedReader(R, Option<u64>)
A Reader used when Transfer-Encoding is chunked
.
EofReader(R)
A Reader used for responses that don't indicate a length or chunked.
Note: This should only used for Response
s. It is illegal for a
Request
to be made with both Content-Length
and
Transfer-Encoding: chunked
missing, as explained from the spec:
If a Transfer-Encoding header field is present in a response and the chunked transfer coding is not the final encoding, the message body length is determined by reading the connection until it is closed by the server. If a Transfer-Encoding header field is present in a request and the chunked transfer coding is not the final encoding, the message body length cannot be determined reliably; the server MUST respond with the 400 (Bad Request) status code and then close the connection.
EmptyReader(R)
A Reader used for messages that should never have a body.
See https://tools.ietf.org/html/rfc7230#section-3.3.3
Methods
impl<R: Read> HttpReader<R>
[src]
pub fn into_inner(self) -> R
[src]
Unwraps this HttpReader and returns the underlying Reader.
ⓘImportant traits for &'a mut Rpub fn get_ref(&self) -> &R
[src]
Gets a borrowed reference to the underlying Reader.
ⓘImportant traits for &'a mut Rpub fn get_mut(&mut self) -> &mut R
[src]
Gets a mutable reference to the underlying Reader.
Trait Implementations
impl<R> Debug for HttpReader<R>
[src]
fn fmt(&self, fmt: &mut Formatter) -> Result
[src]
Formats the value using the given formatter. Read more
impl<R: Read> Read for HttpReader<R>
[src]
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
[src]
Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
unsafe fn initializer(&self) -> Initializer
[src]
read_initializer
)Determines if this Read
er can work with buffers of uninitialized memory. Read more
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
1.0.0[src]
Read all bytes until EOF in this source, placing them into buf
. Read more
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
1.0.0[src]
Read all bytes until EOF in this source, appending them to buf
. Read more
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
1.6.0[src]
Read the exact number of bytes required to fill buf
. Read more
ⓘImportant traits for &'a mut Rfn by_ref(&mut self) -> &mut Self
1.0.0[src]
Creates a "by reference" adaptor for this instance of Read
. Read more
ⓘImportant traits for Bytes<R>fn bytes(self) -> Bytes<Self>
1.0.0[src]
Transforms this Read
instance to an [Iterator
] over its bytes. Read more
ⓘImportant traits for Chars<R>fn chars(self) -> Chars<Self>
[src]
🔬 This is a nightly-only experimental API. (io
)
the semantics of a partial read/write of where errors happen is currently unclear and may change
Transforms this Read
instance to an [Iterator
] over [char
]s. Read more
ⓘImportant traits for Chain<T, U>fn chain<R>(self, next: R) -> Chain<Self, R> where
R: Read,
1.0.0[src]
R: Read,
Creates an adaptor which will chain this stream with another. Read more
ⓘImportant traits for Take<T>fn take(self, limit: u64) -> Take<Self>
1.0.0[src]
Creates an adaptor which will read at most limit
bytes from it. Read more