Struct VacantEntry
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§
§impl<'a, T> VacantEntry<'a, T>
impl<'a, T> VacantEntry<'a, T>
pub 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");
pub 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");
}
pub 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");
pub 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");
pub 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");
pub 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");