Enum http::header::Entry[][src]

pub enum Entry<'a, T: 'a> {
    Occupied(OccupiedEntry<'a, T>),
    Vacant(VacantEntry<'a, T>),
}

A view into a single location in a HeaderMap, which may be vacant or occupied.

Variants

An occupied entry

A vacant entry

Methods

impl<'a, T> Entry<'a, T>
[src]

Ensures a value is in the entry by inserting the default if empty.

Returns a mutable reference to the first value in the entry.

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)
        .expect("valid header names")
        .or_insert(0);
    *counter += 1;
}

assert_eq!(map["content-length"], 2);
assert_eq!(map["x-hello"], 1);

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").unwrap()
    .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.insert(HOST, "world".parse().unwrap());

let res = map.entry("host")
    .expect("host is a valid string")
    .or_insert_with(|| unreachable!());


assert_eq!(res, "world");

Returns a reference to the entry's key

Examples

let mut map = HeaderMap::new();

assert_eq!(map.entry("x-hello").unwrap().key(), "x-hello");

Trait Implementations

impl<'a, T: Debug + 'a> Debug for Entry<'a, T>
[src]

Formats the value using the given formatter. Read more

Auto Trait Implementations

impl<'a, T> Send for Entry<'a, T> where
    T: Send

impl<'a, T> Sync for Entry<'a, T> where
    T: Sync