pub struct OrderedMap<K: Ord, V> { /* private fields */ }Expand description
Ordered key/value map backed by BTreeMap.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut t: OrderedMap<u64, &'static str> = OrderedMap::new();
t.insert(10, "ten");
t.insert(30, "thirty");
t.insert(20, "twenty");
assert_eq!(t.lower_bound(&15), Some((&20, &"twenty")));
assert_eq!(t.min(), Some((&10, &"ten")));Implementations§
Source§impl<K: Ord, V> OrderedMap<K, V>
impl<K: Ord, V> OrderedMap<K, V>
Sourcepub fn new() -> Self
pub fn new() -> Self
Construct an empty map.
§Examples
use dynomite::util::rbtree::OrderedMap;
let m: OrderedMap<u32, u32> = OrderedMap::new();
assert!(m.is_empty());Sourcepub fn insert(&mut self, key: K, value: V) -> Option<V>
pub fn insert(&mut self, key: K, value: V) -> Option<V>
Insert value at key, returning the previous value (if any).
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
assert_eq!(m.insert(1, 10), None);
assert_eq!(m.insert(1, 20), Some(10));Sourcepub fn remove(&mut self, key: &K) -> Option<V>
pub fn remove(&mut self, key: &K) -> Option<V>
Remove the entry at key.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
m.insert(1, 10);
assert_eq!(m.remove(&1), Some(10));Sourcepub fn get(&self, key: &K) -> Option<&V>
pub fn get(&self, key: &K) -> Option<&V>
Look up the value at key.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
m.insert(1, 10);
assert_eq!(m.get(&1), Some(&10));Sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Number of entries.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
m.insert(1, 1);
assert_eq!(m.len(), 1);Sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Whether the map is empty.
§Examples
use dynomite::util::rbtree::OrderedMap;
let m: OrderedMap<u32, u32> = OrderedMap::new();
assert!(m.is_empty());Sourcepub fn clear(&mut self)
pub fn clear(&mut self)
Drop every entry.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
m.insert(1, 1);
m.clear();
assert!(m.is_empty());Sourcepub fn lower_bound(&self, probe: &K) -> Option<(&K, &V)>
pub fn lower_bound(&self, probe: &K) -> Option<(&K, &V)>
Smallest entry whose key is >= probe. Used by the token ring
for “find the owner of this key” queries.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut t: OrderedMap<u64, &str> = OrderedMap::new();
t.insert(10, "a");
t.insert(20, "b");
assert_eq!(t.lower_bound(&15), Some((&20, &"b")));
assert_eq!(t.lower_bound(&25), None);
assert_eq!(t.lower_bound(&20), Some((&20, &"b")));Sourcepub fn iter(&self) -> impl Iterator<Item = (&K, &V)>
pub fn iter(&self) -> impl Iterator<Item = (&K, &V)>
In-order iterator over the entries.
§Examples
use dynomite::util::rbtree::OrderedMap;
let mut m: OrderedMap<u32, u32> = OrderedMap::new();
m.insert(2, 0);
m.insert(1, 0);
let keys: Vec<u32> = m.iter().map(|(k, _)| *k).collect();
assert_eq!(keys, vec![1, 2]);Trait Implementations§
Source§impl<K: Clone + Ord, V: Clone> Clone for OrderedMap<K, V>
impl<K: Clone + Ord, V: Clone> Clone for OrderedMap<K, V>
Source§fn clone(&self) -> OrderedMap<K, V>
fn clone(&self) -> OrderedMap<K, V>
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl<K, V> Freeze for OrderedMap<K, V>
impl<K, V> RefUnwindSafe for OrderedMap<K, V>where
K: RefUnwindSafe,
V: RefUnwindSafe,
impl<K, V> Send for OrderedMap<K, V>
impl<K, V> Sync for OrderedMap<K, V>
impl<K, V> Unpin for OrderedMap<K, V>
impl<K, V> UnsafeUnpin for OrderedMap<K, V>
impl<K, V> UnwindSafe for OrderedMap<K, V>where
K: RefUnwindSafe,
V: RefUnwindSafe,
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
Mutably borrows from an owned value. Read more