pub struct Extensions { /* private fields */ }Expand description
A type map of protocol extensions.
Extensions can be used by Request and Response to store
extra data derived from the underlying protocol.
Implementations§
Source§impl Extensions
 
impl Extensions
Sourcepub fn new() -> Extensions
 
pub fn new() -> Extensions
Create an empty Extensions.
Sourcepub fn insert<T>(&mut self, val: T) -> Option<T>
 
pub fn insert<T>(&mut self, val: T) -> Option<T>
Insert a type into this Extensions.
If a extension of this type already existed, it will be returned and replaced with the new one.
§Example
let mut ext = Extensions::new();
assert!(ext.insert(5i32).is_none());
assert!(ext.insert(4u8).is_none());
assert_eq!(ext.insert(9i32), Some(5i32));Sourcepub fn get<T>(&self) -> Option<&T>
 
pub fn get<T>(&self) -> Option<&T>
Get a reference to a type previously inserted on this Extensions.
§Example
let mut ext = Extensions::new();
assert!(ext.get::<i32>().is_none());
ext.insert(5i32);
assert_eq!(ext.get::<i32>(), Some(&5i32));Sourcepub fn get_mut<T>(&mut self) -> Option<&mut T>
 
pub fn get_mut<T>(&mut self) -> Option<&mut T>
Get a mutable reference to a type previously inserted on this Extensions.
§Example
let mut ext = Extensions::new();
ext.insert(String::from("Hello"));
ext.get_mut::<String>().unwrap().push_str(" World");
assert_eq!(ext.get::<String>().unwrap(), "Hello World");Sourcepub fn get_or_insert<T>(&mut self, value: T) -> &mut T
 
pub fn get_or_insert<T>(&mut self, value: T) -> &mut T
Get a mutable reference to a type, inserting value if not already present on this
Extensions.
§Example
let mut ext = Extensions::new();
*ext.get_or_insert(1i32) += 2;
assert_eq!(*ext.get::<i32>().unwrap(), 3);Sourcepub fn get_or_insert_with<T, F>(&mut self, f: F) -> &mut T
 
pub fn get_or_insert_with<T, F>(&mut self, f: F) -> &mut T
Get a mutable reference to a type, inserting the value created by f if not already present
on this Extensions.
§Example
let mut ext = Extensions::new();
*ext.get_or_insert_with(|| 1i32) += 2;
assert_eq!(*ext.get::<i32>().unwrap(), 3);Sourcepub fn get_or_insert_default<T>(&mut self) -> &mut T
 
pub fn get_or_insert_default<T>(&mut self) -> &mut T
Get a mutable reference to a type, inserting the type’s default value if not already present
on this Extensions.
§Example
let mut ext = Extensions::new();
*ext.get_or_insert_default::<i32>() += 2;
assert_eq!(*ext.get::<i32>().unwrap(), 2);Sourcepub fn remove<T>(&mut self) -> Option<T>
 
pub fn remove<T>(&mut self) -> Option<T>
Remove a type from this Extensions.
If a extension of this type existed, it will be returned.
§Example
let mut ext = Extensions::new();
ext.insert(5i32);
assert_eq!(ext.remove::<i32>(), Some(5i32));
assert!(ext.get::<i32>().is_none());Sourcepub fn clear(&mut self)
 
pub fn clear(&mut self)
Clear the Extensions of all inserted extensions.
§Example
let mut ext = Extensions::new();
ext.insert(5i32);
ext.clear();
assert!(ext.get::<i32>().is_none());Sourcepub fn is_empty(&self) -> bool
 
pub fn is_empty(&self) -> bool
Check whether the extension set is empty or not.
§Example
let mut ext = Extensions::new();
assert!(ext.is_empty());
ext.insert(5i32);
assert!(!ext.is_empty());Sourcepub fn len(&self) -> usize
 
pub fn len(&self) -> usize
Get the number of extensions available.
§Example
let mut ext = Extensions::new();
assert_eq!(ext.len(), 0);
ext.insert(5i32);
assert_eq!(ext.len(), 1);Sourcepub fn extend(&mut self, other: Extensions)
 
pub fn extend(&mut self, other: Extensions)
Extends self with another Extensions.
If an instance of a specific type exists in both, the one in self is overwritten with the
one from other.
§Example
let mut ext_a = Extensions::new();
ext_a.insert(8u8);
ext_a.insert(16u16);
let mut ext_b = Extensions::new();
ext_b.insert(4u8);
ext_b.insert("hello");
ext_a.extend(ext_b);
assert_eq!(ext_a.len(), 3);
assert_eq!(ext_a.get::<u8>(), Some(&4u8));
assert_eq!(ext_a.get::<u16>(), Some(&16u16));
assert_eq!(ext_a.get::<&'static str>().copied(), Some("hello"));Trait Implementations§
Source§impl Clone for Extensions
 
impl Clone for Extensions
Source§fn clone(&self) -> Extensions
 
fn clone(&self) -> Extensions
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Extensions
 
impl Debug for Extensions
Source§impl Default for Extensions
 
impl Default for Extensions
Source§fn default() -> Extensions
 
fn default() -> Extensions
Source§impl<S> FromRequestParts<S> for Extensions
 
impl<S> FromRequestParts<S> for Extensions
Source§type Rejection = Infallible
 
type Rejection = Infallible
Source§fn from_request_parts<'life0, 'life1, 'async_trait>(
    parts: &'life0 mut Parts,
    _state: &'life1 S,
) -> Pin<Box<dyn Future<Output = Result<Extensions, <Extensions as FromRequestParts<S>>::Rejection>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    'life1: 'async_trait,
    Extensions: 'async_trait,
 
fn from_request_parts<'life0, 'life1, 'async_trait>(
    parts: &'life0 mut Parts,
    _state: &'life1 S,
) -> Pin<Box<dyn Future<Output = Result<Extensions, <Extensions as FromRequestParts<S>>::Rejection>> + Send + 'async_trait>>where
    'life0: 'async_trait,
    'life1: 'async_trait,
    Extensions: 'async_trait,
Source§impl IntoResponse for Extensions
 
impl IntoResponse for Extensions
Source§fn into_response(self) -> Response<Body>
 
fn into_response(self) -> Response<Body>
Source§impl IntoResponseParts for Extensions
 
impl IntoResponseParts for Extensions
Source§type Error = Infallible
 
type Error = Infallible
Source§fn into_response_parts(
    self,
    res: ResponseParts,
) -> Result<ResponseParts, <Extensions as IntoResponseParts>::Error>
 
fn into_response_parts( self, res: ResponseParts, ) -> Result<ResponseParts, <Extensions as IntoResponseParts>::Error>
Auto Trait Implementations§
impl Freeze for Extensions
impl !RefUnwindSafe for Extensions
impl Send for Extensions
impl Sync for Extensions
impl Unpin for Extensions
impl !UnwindSafe for Extensions
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<S, T> FromRequest<S, ViaParts> for T
 
impl<S, T> FromRequest<S, ViaParts> for T
Source§type Rejection = <T as FromRequestParts<S>>::Rejection
 
type Rejection = <T as FromRequestParts<S>>::Rejection
Source§impl<T, S> Handler<IntoResponseHandler, S> for T
 
impl<T, S> Handler<IntoResponseHandler, S> for T
Source§fn call(
    self,
    _req: Request<Body>,
    _state: S,
) -> <T as Handler<IntoResponseHandler, S>>::Future
 
fn call( self, _req: Request<Body>, _state: S, ) -> <T as Handler<IntoResponseHandler, S>>::Future
Source§fn layer<L>(self, layer: L) -> Layered<L, Self, T, S>where
    L: Layer<HandlerService<Self, T, S>> + Clone,
    <L as Layer<HandlerService<Self, T, S>>>::Service: Service<Request<Body>>,
 
fn layer<L>(self, layer: L) -> Layered<L, Self, T, S>where
    L: Layer<HandlerService<Self, T, S>> + Clone,
    <L as Layer<HandlerService<Self, T, S>>>::Service: Service<Request<Body>>,
tower::Layer to the handler. Read moreSource§fn with_state(self, state: S) -> HandlerService<Self, T, S>
 
fn with_state(self, state: S) -> HandlerService<Self, T, S>
Service by providing the stateSource§impl<H, T> HandlerWithoutStateExt<T> for H
 
impl<H, T> HandlerWithoutStateExt<T> for H
Source§fn into_service(self) -> HandlerService<H, T, ()>
 
fn into_service(self) -> HandlerService<H, T, ()>
Service and no state.Source§fn into_make_service(self) -> IntoMakeService<HandlerService<H, T, ()>>
 
fn into_make_service(self) -> IntoMakeService<HandlerService<H, T, ()>>
MakeService and no state. Read moreSource§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
 
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
 
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoRequest<T> for T
 
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
 
fn into_request(self) -> Request<T>
T in a tonic::Request