pub struct VacantEntry<'a, T> { /* private fields */ }
Expand description
A view into a single empty location in a HeaderMap
.
This struct is returned as part of the Entry
enum.
Implementations§
source§impl<'a, T> VacantEntry<'a, T>
impl<'a, T> VacantEntry<'a, T>
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().as_str(), "x-hello");
sourcepub fn into_key(self) -> HeaderName
pub fn into_key(self) -> HeaderName
Take ownership of the key
§Examples
let mut map = HeaderMap::new();
if let Entry::Vacant(v) = map.entry("x-hello") {
assert_eq!(v.into_key().as_str(), "x-hello");
}
sourcepub fn insert(self, value: T) -> &'a mut T
pub fn insert(self, value: T) -> &'a mut T
Insert the value into the entry.
The value will be associated with this entry’s key. A mutable reference to the inserted value will be returned.
§Examples
let mut map = HeaderMap::new();
if let Entry::Vacant(v) = map.entry("x-hello") {
v.insert("world".parse().unwrap());
}
assert_eq!(map["x-hello"], "world");
sourcepub fn try_insert(self, value: T) -> Result<&'a mut T, MaxSizeReached>
pub fn try_insert(self, value: T) -> Result<&'a mut T, MaxSizeReached>
Insert the value into the entry.
The value will be associated with this entry’s key. A mutable reference to the inserted value will be returned.
§Examples
let mut map = HeaderMap::new();
if let Entry::Vacant(v) = map.entry("x-hello") {
v.insert("world".parse().unwrap());
}
assert_eq!(map["x-hello"], "world");
sourcepub fn insert_entry(self, value: T) -> OccupiedEntry<'a, T>
pub fn insert_entry(self, value: T) -> OccupiedEntry<'a, T>
Insert the value into the entry.
The value will be associated with this entry’s key. The new
OccupiedEntry
is returned, allowing for further manipulation.
§Examples
let mut map = HeaderMap::new();
if let Entry::Vacant(v) = map.try_entry("x-hello").unwrap() {
let mut e = v.try_insert_entry("world".parse().unwrap()).unwrap();
e.insert("world2".parse().unwrap());
}
assert_eq!(map["x-hello"], "world2");
sourcepub fn try_insert_entry(
self,
value: T,
) -> Result<OccupiedEntry<'a, T>, MaxSizeReached>
pub fn try_insert_entry( self, value: T, ) -> Result<OccupiedEntry<'a, T>, MaxSizeReached>
Insert the value into the entry.
The value will be associated with this entry’s key. The new
OccupiedEntry
is returned, allowing for further manipulation.
§Examples
let mut map = HeaderMap::new();
if let Entry::Vacant(v) = map.try_entry("x-hello").unwrap() {
let mut e = v.try_insert_entry("world".parse().unwrap()).unwrap();
e.insert("world2".parse().unwrap());
}
assert_eq!(map["x-hello"], "world2");
Trait Implementations§
Auto Trait Implementations§
impl<'a, T> !Freeze for VacantEntry<'a, T>
impl<'a, T> RefUnwindSafe for VacantEntry<'a, T>where
T: RefUnwindSafe,
impl<'a, T> Send for VacantEntry<'a, T>where
T: Send,
impl<'a, T> Sync for VacantEntry<'a, T>where
T: Sync,
impl<'a, T> Unpin for VacantEntry<'a, T>
impl<'a, T> !UnwindSafe for VacantEntry<'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> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> FsChangeNote for T
impl<T> FsChangeNote for 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