http_types::transfer

Struct TE

source
pub struct TE { /* private fields */ }
Expand description

Client header advertising the transfer encodings the user agent is willing to accept.

MDN Documentation

§Specifications

§Examples

use http_types::transfer::{TE, TransferEncoding, Encoding, EncodingProposal};
use http_types::Response;

let mut te = TE::new();
te.push(EncodingProposal::new(Encoding::Brotli, Some(0.8))?);
te.push(EncodingProposal::new(Encoding::Gzip, Some(0.4))?);
te.push(EncodingProposal::new(Encoding::Identity, None)?);

let mut res = Response::new(200);
let encoding = te.negotiate(&[Encoding::Brotli, Encoding::Gzip])?;
encoding.apply(&mut res);

assert_eq!(res["Content-Encoding"], "br");

Implementations§

source§

impl TE

source

pub fn new() -> Self

Create a new instance of TE.

source

pub fn from_headers(headers: impl AsRef<Headers>) -> Result<Option<Self>>

Create an instance of TE from a Headers instance.

source

pub fn push(&mut self, prop: impl Into<EncodingProposal>)

Push a directive into the list of entries.

source

pub fn wildcard(&self) -> bool

Returns true if a wildcard directive was passed.

source

pub fn set_wildcard(&mut self, wildcard: bool)

Set the wildcard directive.

source

pub fn sort(&mut self)

Sort the header directives by weight.

Headers with a higher q= value will be returned first. If two directives have the same weight, the directive that was declared later will be returned first.

source

pub fn negotiate(&mut self, available: &[Encoding]) -> Result<TransferEncoding>

Determine the most suitable Transfer-Encoding encoding.

§Errors

If no suitable encoding is found, an error with the status of 406 will be returned.

source

pub fn apply(&self, headers: impl AsMut<Headers>)

Sets the Accept-Encoding header.

source

pub fn name(&self) -> HeaderName

Get the HeaderName.

source

pub fn value(&self) -> HeaderValue

Get the HeaderValue.

source

pub fn iter(&self) -> Iter<'_>

An iterator visiting all entries.

source

pub fn iter_mut(&mut self) -> IterMut<'_>

An iterator visiting all entries.

Trait Implementations§

source§

impl Debug for TE

source§

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

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

impl<'a> IntoIterator for &'a TE

source§

type Item = &'a EncodingProposal

The type of the elements being iterated over.
source§

type IntoIter = Iter<'a>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl<'a> IntoIterator for &'a mut TE

source§

type Item = &'a mut EncodingProposal

The type of the elements being iterated over.
source§

type IntoIter = IterMut<'a>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl IntoIterator for TE

source§

type Item = EncodingProposal

The type of the elements being iterated over.
source§

type IntoIter = IntoIter

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl ToHeaderValues for TE

source§

type Iter = IntoIter<HeaderValue>

Returned iterator over header values which this type may correspond to.
source§

fn to_header_values(&self) -> Result<Self::Iter>

Converts this object to an iterator of resolved HeaderValues.

Auto Trait Implementations§

§

impl Freeze for TE

§

impl RefUnwindSafe for TE

§

impl Send for TE

§

impl Sync for TE

§

impl Unpin for TE

§

impl UnwindSafe for TE

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<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T