Struct headers_core::header::VacantEntry
source · pub struct VacantEntry<'a, T> {
map: &'a mut HeaderMap<T>,
key: HeaderName,
hash: HashValue,
probe: usize,
danger: bool,
}
Expand description
A view into a single empty location in a HeaderMap
.
This struct is returned as part of the Entry
enum.
Fields§
§map: &'a mut HeaderMap<T>
§key: HeaderName
§hash: HashValue
§probe: usize
§danger: bool
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");