pub enum Entry<'a, T>where
T: 'a,{
Occupied(OccupiedEntry<'a, T>),
Vacant(VacantEntry<'a, T>),
}
Expand description
A view into a single location in a HeaderMap
, which may be vacant or occupied.
Variants§
Implementations§
source§impl<'a, T> Entry<'a, T>
impl<'a, T> Entry<'a, T>
sourcepub fn or_insert(self, default: T) -> &'a mut T
pub fn or_insert(self, default: T) -> &'a mut T
Ensures a value is in the entry by inserting the default if empty.
Returns a mutable reference to the first value in the entry.
§Panics
This method panics if capacity exceeds max HeaderMap
capacity
§Examples
let mut map: HeaderMap<u32> = HeaderMap::default();
let headers = &[
"content-length",
"x-hello",
"Content-Length",
"x-world",
];
for &header in headers {
let counter = map.entry(header)
.or_insert(0);
*counter += 1;
}
assert_eq!(map["content-length"], 2);
assert_eq!(map["x-hello"], 1);
sourcepub fn or_try_insert(self, default: T) -> Result<&'a mut T, MaxSizeReached>
pub fn or_try_insert(self, default: T) -> Result<&'a mut T, MaxSizeReached>
Ensures a value is in the entry by inserting the default if empty.
Returns a mutable reference to the first value in the entry.
§Errors
This function may return an error if HeaderMap
exceeds max capacity
§Examples
let mut map: HeaderMap<u32> = HeaderMap::default();
let headers = &[
"content-length",
"x-hello",
"Content-Length",
"x-world",
];
for &header in headers {
let counter = map.entry(header)
.or_try_insert(0)
.unwrap();
*counter += 1;
}
assert_eq!(map["content-length"], 2);
assert_eq!(map["x-hello"], 1);
sourcepub fn or_insert_with<F>(self, default: F) -> &'a mut Twhere
F: FnOnce() -> T,
pub fn or_insert_with<F>(self, default: F) -> &'a mut Twhere
F: FnOnce() -> T,
Ensures a value is in the entry by inserting the result of the default function if empty.
The default function is not called if the entry exists in the map. Returns a mutable reference to the first value in the entry.
§Examples
Basic usage.
let mut map = HeaderMap::new();
let res = map.entry("x-hello")
.or_insert_with(|| "world".parse().unwrap());
assert_eq!(res, "world");
The default function is not called if the entry exists in the map.
let mut map = HeaderMap::new();
map.try_insert(HOST, "world".parse().unwrap()).unwrap();
let res = map.try_entry("host")
.unwrap()
.or_try_insert_with(|| unreachable!())
.unwrap();
assert_eq!(res, "world");
sourcepub fn or_try_insert_with<F>(
self,
default: F,
) -> Result<&'a mut T, MaxSizeReached>where
F: FnOnce() -> T,
pub fn or_try_insert_with<F>(
self,
default: F,
) -> Result<&'a mut T, MaxSizeReached>where
F: FnOnce() -> T,
Ensures a value is in the entry by inserting the result of the default function if empty.
The default function is not called if the entry exists in the map. Returns a mutable reference to the first value in the entry.
§Examples
Basic usage.
let mut map = HeaderMap::new();
let res = map.entry("x-hello")
.or_insert_with(|| "world".parse().unwrap());
assert_eq!(res, "world");
The default function is not called if the entry exists in the map.
let mut map = HeaderMap::new();
map.try_insert(HOST, "world".parse().unwrap()).unwrap();
let res = map.try_entry("host")
.unwrap()
.or_try_insert_with(|| unreachable!())
.unwrap();
assert_eq!(res, "world");
sourcepub fn key(&self) -> &HeaderName
pub fn key(&self) -> &HeaderName
Returns a reference to the entry’s key
§Examples
let mut map = HeaderMap::new();
assert_eq!(map.entry("x-hello").key(), "x-hello");
Trait Implementations§
Auto Trait Implementations§
impl<'a, T> !Freeze for Entry<'a, T>
impl<'a, T> RefUnwindSafe for Entry<'a, T>where
T: RefUnwindSafe,
impl<'a, T> Send for Entry<'a, T>where
T: Send,
impl<'a, T> Sync for Entry<'a, T>where
T: Sync,
impl<'a, T> Unpin for Entry<'a, T>
impl<'a, T> !UnwindSafe for Entry<'a, T>
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§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> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more