refactor(header): remove some lifetime transmutes for keys in VecMap

This commit is contained in:
Sean McArthur
2017-04-26 13:19:23 -07:00
parent 38e60f7267
commit 8d6d9a21af
2 changed files with 36 additions and 9 deletions

View File

@@ -4,12 +4,14 @@ pub struct VecMap<K, V> {
}
impl<K: PartialEq, V> VecMap<K, V> {
#[inline]
pub fn with_capacity(cap: usize) -> VecMap<K, V> {
VecMap {
vec: Vec::with_capacity(cap)
}
}
#[inline]
pub fn insert(&mut self, key: K, value: V) {
match self.find(&key) {
Some(pos) => self.vec[pos] = (key, value),
@@ -17,6 +19,7 @@ impl<K: PartialEq, V> VecMap<K, V> {
}
}
#[inline]
pub fn entry(&mut self, key: K) -> Entry<K, V> {
match self.find(&key) {
Some(pos) => Entry::Occupied(OccupiedEntry {
@@ -30,31 +33,47 @@ impl<K: PartialEq, V> VecMap<K, V> {
}
}
pub fn get(&self, key: &K) -> Option<&V> {
#[inline]
pub fn get<K2>(&self, key: &K2) -> Option<&V>
where K2: PartialEq<K> + ?Sized {
self.find(key).map(move |pos| &self.vec[pos].1)
}
pub fn get_mut(&mut self, key: &K) -> Option<&mut V> {
#[inline]
pub fn get_mut<K2>(&mut self, key: &K2) -> Option<&mut V>
where K2: PartialEq<K> {
self.find(key).map(move |pos| &mut self.vec[pos].1)
}
pub fn contains_key(&self, key: &K) -> bool {
#[inline]
pub fn contains_key<K2>(&self, key: &K2) -> bool
where K2: PartialEq<K> {
self.find(key).is_some()
}
#[inline]
pub fn len(&self) -> usize { self.vec.len() }
#[inline]
pub fn is_empty(&self) -> bool { self.vec.is_empty() }
#[inline]
pub fn iter(&self) -> ::std::slice::Iter<(K, V)> {
self.vec.iter()
}
pub fn remove(&mut self, key: &K) -> Option<V> {
#[inline]
pub fn remove<K2>(&mut self, key: &K2) -> Option<V>
where K2: PartialEq<K> + ?Sized {
self.find(key).map(|pos| self.vec.remove(pos)).map(|(_, v)| v)
}
#[inline]
pub fn clear(&mut self) {
self.vec.clear();
}
fn find(&self, key: &K) -> Option<usize> {
#[inline]
fn find<K2>(&self, key: &K2) -> Option<usize>
where K2: PartialEq<K> + ?Sized {
self.vec.iter().position(|entry| key == &entry.0)
}
}

View File

@@ -464,7 +464,7 @@ impl Headers {
/// ```
pub fn get_raw(&self, name: &str) -> Option<&Raw> {
self.data
.get(&HeaderName(UniCase(Cow::Borrowed(unsafe { mem::transmute::<&str, &str>(name) }))))
.get(name)
.map(Item::raw)
}
@@ -517,9 +517,7 @@ impl Headers {
/// Remove a header by name.
pub fn remove_raw(&mut self, name: &str) {
trace!("Headers.remove_raw( {:?} )", name);
self.data.remove(
&HeaderName(UniCase(Cow::Borrowed(unsafe { mem::transmute::<&str, &str>(name) })))
);
self.data.remove(name);
}
@@ -685,6 +683,16 @@ impl PartialEq for HeaderName {
}
}
impl PartialEq<HeaderName> for str {
fn eq(&self, other: &HeaderName) -> bool {
let k = other.as_ref();
if self.len() == k.len() && self.as_ptr() == k.as_ptr() {
true
} else {
other.0 == self
}
}
}
#[cfg(test)]
mod tests {