123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791 |
- // Copyright 2017-2018 By [email protected].
- //
- // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
- // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
- // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
- // option. This file may not be copied, modified, or distributed
- // except according to those terms.
- // This file brings from https://github.com/tickbh/rbtree-rs/blob/master/src/lib.rs
- // Thanks to the author tickbh
- #![allow(dead_code)]
- use core::cmp::Ord;
- use core::fmt::{self, Debug};
- use core::cmp::Ordering;
- use core::ptr;
- use core::iter::{IntoIterator, FromIterator};
- use core::marker;
- use core::mem;
- use core::ops::Index;
- use alloc::boxed::Box;
- use crate::kdebug;
- #[derive(Debug, Copy, Clone, PartialEq, Eq)]
- enum Color {
- Red,
- Black,
- }
- /*****************RBTreeNode***************************/
- struct RBTreeNode<K: Ord, V> {
- color: Color,
- left: NodePtr<K, V>,
- right: NodePtr<K, V>,
- parent: NodePtr<K, V>,
- key: K,
- value: V,
- }
- impl<K: Ord, V> RBTreeNode<K, V> {
- #[inline]
- fn pair(self) -> (K, V) {
- (self.key, self.value)
- }
- }
- impl<K, V> Debug for RBTreeNode<K, V>
- where
- K: Ord + Debug,
- V: Debug,
- {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- write!(f, "k:{:?} v:{:?} c:{:?}", self.key, self.value, self.color)
- }
- }
- /*****************NodePtr***************************/
- #[derive(Debug)]
- struct NodePtr<K: Ord, V>(*mut RBTreeNode<K, V>);
- impl<K: Ord, V> Clone for NodePtr<K, V> {
- fn clone(&self) -> NodePtr<K, V> {
- NodePtr(self.0)
- }
- }
- impl<K: Ord, V> Copy for NodePtr<K, V> {}
- impl<K: Ord, V> Ord for NodePtr<K, V> {
- fn cmp(&self, other: &NodePtr<K, V>) -> Ordering {
- unsafe { (*self.0).key.cmp(&(*other.0).key) }
- }
- }
- impl<K: Ord, V> PartialOrd for NodePtr<K, V> {
- fn partial_cmp(&self, other: &NodePtr<K, V>) -> Option<Ordering> {
- unsafe { Some((*self.0).key.cmp(&(*other.0).key)) }
- }
- }
- impl<K: Ord, V> PartialEq for NodePtr<K, V> {
- fn eq(&self, other: &NodePtr<K, V>) -> bool {
- self.0 == other.0
- }
- }
- impl<K: Ord, V> Eq for NodePtr<K, V> {}
- impl<K: Ord, V> NodePtr<K, V> {
- fn new(k: K, v: V) -> NodePtr<K, V> {
- let node = RBTreeNode {
- color: Color::Black,
- left: NodePtr::null(),
- right: NodePtr::null(),
- parent: NodePtr::null(),
- key: k,
- value: v,
- };
- NodePtr(Box::into_raw(Box::new(node)))
- }
- #[inline]
- fn set_color(&mut self, color: Color) {
- if self.is_null() {
- return;
- }
- unsafe {
- (*self.0).color = color;
- }
- }
- #[inline]
- fn set_red_color(&mut self) {
- self.set_color(Color::Red);
- }
- #[inline]
- fn set_black_color(&mut self) {
- self.set_color(Color::Black);
- }
- #[inline]
- fn get_color(&self) -> Color {
- if self.is_null() {
- return Color::Black;
- }
- unsafe { (*self.0).color }
- }
- #[inline]
- fn is_red_color(&self) -> bool {
- if self.is_null() {
- return false;
- }
- unsafe { (*self.0).color == Color::Red }
- }
- #[inline]
- fn is_black_color(&self) -> bool {
- if self.is_null() {
- return true;
- }
- unsafe { (*self.0).color == Color::Black }
- }
- #[inline]
- fn is_left_child(&self) -> bool {
- self.parent().left() == *self
- }
- #[inline]
- fn is_right_child(&self) -> bool {
- self.parent().right() == *self
- }
- #[inline]
- fn min_node(self) -> NodePtr<K, V> {
- let mut temp = self.clone();
- while !temp.left().is_null() {
- temp = temp.left();
- }
- return temp;
- }
- #[inline]
- fn max_node(self) -> NodePtr<K, V> {
- let mut temp = self.clone();
- while !temp.right().is_null() {
- temp = temp.right();
- }
- return temp;
- }
- #[inline]
- fn next(self) -> NodePtr<K, V> {
- if !self.right().is_null() {
- self.right().min_node()
- } else {
- let mut temp = self;
- loop {
- if temp.parent().is_null() {
- return NodePtr::null();
- }
- if temp.is_left_child() {
- return temp.parent();
- }
- temp = temp.parent();
- }
- }
- }
- #[inline]
- fn prev(self) -> NodePtr<K, V> {
- if !self.left().is_null() {
- self.left().max_node()
- } else {
- let mut temp = self;
- loop {
- if temp.parent().is_null() {
- return NodePtr::null();
- }
- if temp.is_right_child() {
- return temp.parent();
- }
- temp = temp.parent();
- }
- }
- }
- #[inline]
- fn set_parent(&mut self, parent: NodePtr<K, V>) {
- if self.is_null() {
- return;
- }
- unsafe { (*self.0).parent = parent }
- }
- #[inline]
- fn set_left(&mut self, left: NodePtr<K, V>) {
- if self.is_null() {
- return;
- }
- unsafe { (*self.0).left = left }
- }
- #[inline]
- fn set_right(&mut self, right: NodePtr<K, V>) {
- if self.is_null() {
- return;
- }
- unsafe { (*self.0).right = right }
- }
- #[inline]
- fn parent(&self) -> NodePtr<K, V> {
- if self.is_null() {
- return NodePtr::null();
- }
- unsafe { (*self.0).parent.clone() }
- }
- #[inline]
- fn left(&self) -> NodePtr<K, V> {
- if self.is_null() {
- return NodePtr::null();
- }
- unsafe { (*self.0).left.clone() }
- }
- #[inline]
- fn right(&self) -> NodePtr<K, V> {
- if self.is_null() {
- return NodePtr::null();
- }
- unsafe { (*self.0).right.clone() }
- }
- #[inline]
- fn null() -> NodePtr<K, V> {
- NodePtr(ptr::null_mut())
- }
- #[inline]
- fn is_null(&self) -> bool {
- self.0.is_null()
- }
- }
- impl<K: Ord + Clone, V: Clone> NodePtr<K, V> {
- unsafe fn deep_clone(&self) -> NodePtr<K, V> {
- let mut node = NodePtr::new((*self.0).key.clone(), (*self.0).value.clone());
- if !self.left().is_null() {
- node.set_left(self.left().deep_clone());
- node.left().set_parent(node);
- }
- if !self.right().is_null() {
- node.set_right(self.right().deep_clone());
- node.right().set_parent(node);
- }
- node
- }
- }
- /// A red black tree implemented with Rust
- /// It is required that the keys implement the [`Ord`] traits.
- /// # Examples
- /// ```rust
- /// use rbtree::RBTree;
- /// // type inference lets us omit an explicit type signature (which
- /// // would be `RBTree<&str, &str>` in this example).
- /// let mut book_reviews = RBTree::new();
- ///
- /// // review some books.
- /// book_reviews.insert("Adventures of Huckleberry Finn", "My favorite book.");
- /// book_reviews.insert("Grimms' Fairy Tales", "Masterpiece.");
- /// book_reviews.insert("Pride and Prejudice", "Very enjoyable.");
- /// book_reviews.insert("The Adventures of Sherlock Holmes", "Eye lyked it alot.");
- ///
- /// // check for a specific one.
- /// if !book_reviews.contains_key(&"Les Misérables") {
- /// kdebug!(
- /// "We've got {} reviews, but Les Misérables ain't one.",
- /// book_reviews.len()
- /// );
- /// }
- ///
- /// // oops, this review has a lot of spelling mistakes, let's delete it.
- /// book_reviews.remove(&"The Adventures of Sherlock Holmes");
- ///
- /// // look up the values associated with some keys.
- /// let to_find = ["Pride and Prejudice", "Alice's Adventure in Wonderland"];
- /// for book in &to_find {
- /// match book_reviews.get(book) {
- /// Some(review) => kdebug!("{}: {}", book, review),
- /// None => kdebug!("{} is unreviewed.", book),
- /// }
- /// }
- ///
- /// // iterate over everything.
- /// for (book, review) in book_reviews.iter() {
- /// kdebug!("{}: \"{}\"", book, review);
- /// }
- ///
- /// book_reviews.print_tree();
- /// ```
- ///
- /// // A `RBTree` with fixed list of elements can be initialized from an array:
- /// ```
- /// use rbtree::RBTree;
- /// let timber_resources: RBTree<&str, i32> =
- /// [("Norway", 100),
- /// ("Denmark", 50),
- /// ("Iceland", 10)]
- /// .iter().cloned().collect();
- /// // use the values stored in rbtree
- /// ```
- pub struct RBTree<K: Ord, V> {
- root: NodePtr<K, V>,
- len: usize,
- }
- // Drop all owned pointers if the tree is dropped
- impl<K: Ord, V> Drop for RBTree<K, V> {
- #[inline]
- fn drop(&mut self) {
- self.clear();
- }
- }
- /// If key and value are both impl Clone, we can call clone to get a copy.
- impl<K: Ord + Clone, V: Clone> Clone for RBTree<K, V> {
- fn clone(&self) -> RBTree<K, V> {
- unsafe {
- let mut new = RBTree::new();
- new.root = self.root.deep_clone();
- new.len = self.len;
- new
- }
- }
- }
- impl<K, V> Debug for RBTree<K, V>
- where
- K: Ord + Debug,
- V: Debug,
- {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- f.debug_map().entries(self.iter()).finish()
- }
- }
- /// This is a method to help us to get inner struct.
- impl<K: Ord + Debug, V: Debug> RBTree<K, V> {
- fn tree_print(&self, node: NodePtr<K, V>, direction: i32) {
- if node.is_null() {
- return;
- }
- if direction == 0 {
- unsafe {
- kdebug!("'{:?}' is root node", (*node.0));
- }
- } else {
- let direct = if direction == -1 { "left" } else { "right" };
- unsafe {
- kdebug!(
- "{:?} is {:?}'s {:?} child ",
- (*node.0),
- *node.parent().0,
- direct
- );
- }
- }
- self.tree_print(node.left(), -1);
- self.tree_print(node.right(), 1);
- }
- pub fn print_tree(&self) {
- if self.root.is_null() {
- kdebug!("This is a empty tree");
- return;
- }
- kdebug!("This tree size = {:?}, begin:-------------", self.len());
- self.tree_print(self.root, 0);
- kdebug!("end--------------------------");
- }
- }
- /// all key be same, but it has multi key, if has multi key, it perhaps no correct
- impl<K, V> PartialEq for RBTree<K, V>
- where
- K: Eq + Ord,
- V: PartialEq,
- {
- fn eq(&self, other: &RBTree<K, V>) -> bool {
- if self.len() != other.len() {
- return false;
- }
- self.iter().all(|(key, value)| {
- other.get(key).map_or(false, |v| *value == *v)
- })
- }
- }
- impl<K, V> Eq for RBTree<K, V>
- where
- K: Eq + Ord,
- V: Eq,
- {
- }
- impl<'a, K, V> Index<&'a K> for RBTree<K, V>
- where
- K: Ord,
- {
- type Output = V;
- #[inline]
- fn index(&self, index: &K) -> &V {
- self.get(index).expect("no entry found for key")
- }
- }
- impl<K: Ord, V> FromIterator<(K, V)> for RBTree<K, V> {
- fn from_iter<T: IntoIterator<Item = (K, V)>>(iter: T) -> RBTree<K, V> {
- let mut tree = RBTree::new();
- tree.extend(iter);
- tree
- }
- }
- /// RBTree into iter
- impl<K: Ord, V> Extend<(K, V)> for RBTree<K, V> {
- fn extend<T: IntoIterator<Item = (K, V)>>(&mut self, iter: T) {
- let iter = iter.into_iter();
- for (k, v) in iter {
- self.insert(k, v);
- }
- }
- }
- /// provide the rbtree all keys
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// for i in 1..6 {
- /// m.insert(i, i);
- /// }
- /// let vec = vec![1, 2, 3, 4, 5];
- /// let key_vec: Vec<_> = m.keys().cloned().collect();
- /// assert_eq!(vec, key_vec);
- /// ```
- pub struct Keys<'a, K: Ord + 'a, V: 'a> {
- inner: Iter<'a, K, V>,
- }
- impl<'a, K: Ord, V> Clone for Keys<'a, K, V> {
- fn clone(&self) -> Keys<'a, K, V> {
- Keys { inner: self.inner.clone() }
- }
- }
- impl<'a, K: Ord + Debug, V> fmt::Debug for Keys<'a, K, V> {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- f.debug_list().entries(self.clone()).finish()
- }
- }
- impl<'a, K: Ord, V> Iterator for Keys<'a, K, V> {
- type Item = &'a K;
- #[inline]
- fn next(&mut self) -> Option<&'a K> {
- self.inner.next().map(|(k, _)| k)
- }
- #[inline]
- fn size_hint(&self) -> (usize, Option<usize>) {
- self.inner.size_hint()
- }
- }
- /// provide the rbtree all values order by key
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// m.insert(2, 5);
- /// m.insert(1, 6);
- /// m.insert(3, 8);
- /// m.insert(4, 9);
- /// let vec = vec![6, 5, 8, 9];
- /// let key_vec: Vec<_> = m.values().cloned().collect();
- /// assert_eq!(vec, key_vec);
- /// ```
- pub struct Values<'a, K: 'a + Ord, V: 'a> {
- inner: Iter<'a, K, V>,
- }
- impl<'a, K: Ord, V> Clone for Values<'a, K, V> {
- fn clone(&self) -> Values<'a, K, V> {
- Values { inner: self.inner.clone() }
- }
- }
- impl<'a, K: Ord + Debug, V: Debug> fmt::Debug for Values<'a, K, V> {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- f.debug_list().entries(self.clone()).finish()
- }
- }
- impl<'a, K: Ord, V> Iterator for Values<'a, K, V> {
- type Item = &'a V;
- #[inline]
- fn next(&mut self) -> Option<&'a V> {
- self.inner.next().map(|(_, v)| v)
- }
- #[inline]
- fn size_hint(&self) -> (usize, Option<usize>) {
- self.inner.size_hint()
- }
- }
- /// provide the rbtree all values and it can be modify
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// for i in 0..32 {
- /// m.insert(i, i);
- /// }
- /// assert_eq!(m.len(), 32);
- /// for v in m.values_mut() {
- /// *v *= 2;
- /// }
- /// for i in 0..32 {
- /// assert_eq!(m.get(&i).unwrap(), &(i * 2));
- /// }
- /// ```
- pub struct ValuesMut<'a, K: 'a + Ord, V: 'a> {
- inner: IterMut<'a, K, V>,
- }
- impl<'a, K: Ord, V> Clone for ValuesMut<'a, K, V> {
- fn clone(&self) -> ValuesMut<'a, K, V> {
- ValuesMut { inner: self.inner.clone() }
- }
- }
- impl<'a, K: Ord + Debug, V: Debug> fmt::Debug for ValuesMut<'a, K, V> {
- fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
- f.debug_list().entries(self.clone()).finish()
- }
- }
- impl<'a, K: Ord, V> Iterator for ValuesMut<'a, K, V> {
- type Item = &'a mut V;
- #[inline]
- fn next(&mut self) -> Option<&'a mut V> {
- self.inner.next().map(|(_, v)| v)
- }
- #[inline]
- fn size_hint(&self) -> (usize, Option<usize>) {
- self.inner.size_hint()
- }
- }
- /// Convert RBTree to iter, move out the tree.
- pub struct IntoIter<K: Ord, V> {
- head: NodePtr<K, V>,
- tail: NodePtr<K, V>,
- len: usize,
- }
- // Drop all owned pointers if the collection is dropped
- impl<K: Ord, V> Drop for IntoIter<K, V> {
- #[inline]
- fn drop(&mut self) {
- for (_, _) in self {}
- }
- }
- impl<K: Ord, V> Iterator for IntoIter<K, V> {
- type Item = (K, V);
- fn next(&mut self) -> Option<(K, V)> {
- if self.len == 0 {
- return None;
- }
- if self.head.is_null() {
- return None;
- }
- let next = self.head.next();
- let (k, v) = unsafe {
- (
- core::ptr::read(&(*self.head.0).key),
- core::ptr::read(&(*self.head.0).value),
- )
- };
- self.head = next;
- self.len -= 1;
- Some((k, v))
- }
- fn size_hint(&self) -> (usize, Option<usize>) {
- (self.len, Some(self.len))
- }
- }
- impl<K: Ord, V> DoubleEndedIterator for IntoIter<K, V> {
- #[inline]
- fn next_back(&mut self) -> Option<(K, V)> {
- if self.len == 0 {
- return None;
- }
- if self.tail.is_null() {
- return None;
- }
- let prev = self.tail.prev();
- let obj = unsafe { Box::from_raw(self.tail.0) };
- let (k, v) = obj.pair();
- self.tail = prev;
- self.len -= 1;
- Some((k, v))
- }
- }
- /// provide iter ref for RBTree
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// for i in 0..32 {
- /// m.insert(i, i * 2);
- /// }
- /// assert_eq!(m.len(), 32);
- /// let mut observed: u32 = 0;
- /// for (k, v) in m.iter() {
- /// assert_eq!(*v, *k * 2);
- /// observed |= 1 << *k;
- /// }
- /// assert_eq!(observed, 0xFFFF_FFFF);
- /// ```
- pub struct Iter<'a, K: Ord + 'a, V: 'a> {
- head: NodePtr<K, V>,
- tail: NodePtr<K, V>,
- len: usize,
- _marker: marker::PhantomData<&'a ()>,
- }
- impl<'a, K: Ord + 'a, V: 'a> Clone for Iter<'a, K, V> {
- fn clone(&self) -> Iter<'a, K, V> {
- Iter {
- head: self.head,
- tail: self.tail,
- len: self.len,
- _marker: self._marker,
- }
- }
- }
- impl<'a, K: Ord + 'a, V: 'a> Iterator for Iter<'a, K, V> {
- type Item = (&'a K, &'a V);
- fn next(&mut self) -> Option<(&'a K, &'a V)> {
- if self.len == 0 {
- return None;
- }
- if self.head.is_null() {
- return None;
- }
- let (k, v) = unsafe { (&(*self.head.0).key, &(*self.head.0).value) };
- self.head = self.head.next();
- self.len -= 1;
- Some((k, v))
- }
- fn size_hint(&self) -> (usize, Option<usize>) {
- (self.len, Some(self.len))
- }
- }
- impl<'a, K: Ord + 'a, V: 'a> DoubleEndedIterator for Iter<'a, K, V> {
- #[inline]
- fn next_back(&mut self) -> Option<(&'a K, &'a V)> {
- // kdebug!("len = {:?}", self.len);
- if self.len == 0 {
- return None;
- }
- if self.tail == self.head {
- return None;
- }
- let (k, v) = unsafe { (&(*self.tail.0).key, &(*self.tail.0).value) };
- self.tail = self.tail.prev();
- self.len -= 1;
- Some((k, v))
- }
- }
- /// provide iter mut ref for RBTree
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// for i in 0..32 {
- /// m.insert(i, i);
- /// }
- /// assert_eq!(m.len(), 32);
- /// for (_, v) in m.iter_mut() {
- /// *v *= 2;
- /// }
- /// for i in 0..32 {
- /// assert_eq!(m.get(&i).unwrap(), &(i * 2));
- /// }
- /// ```
- pub struct IterMut<'a, K: Ord + 'a, V: 'a> {
- head: NodePtr<K, V>,
- tail: NodePtr<K, V>,
- len: usize,
- _marker: marker::PhantomData<&'a ()>,
- }
- impl<'a, K: Ord + 'a, V: 'a> Clone for IterMut<'a, K, V> {
- fn clone(&self) -> IterMut<'a, K, V> {
- IterMut {
- head: self.head,
- tail: self.tail,
- len: self.len,
- _marker: self._marker,
- }
- }
- }
- impl<'a, K: Ord + 'a, V: 'a> Iterator for IterMut<'a, K, V> {
- type Item = (&'a K, &'a mut V);
- fn next(&mut self) -> Option<(&'a K, &'a mut V)> {
- if self.len == 0 {
- return None;
- }
- if self.head.is_null() {
- return None;
- }
- let (k, v) = unsafe { (&(*self.head.0).key, &mut (*self.head.0).value) };
- self.head = self.head.next();
- self.len -= 1;
- Some((k, v))
- }
- fn size_hint(&self) -> (usize, Option<usize>) {
- (self.len, Some(self.len))
- }
- }
- impl<'a, K: Ord + 'a, V: 'a> DoubleEndedIterator for IterMut<'a, K, V> {
- #[inline]
- fn next_back(&mut self) -> Option<(&'a K, &'a mut V)> {
- if self.len == 0 {
- return None;
- }
- if self.tail == self.head {
- return None;
- }
- let (k, v) = unsafe { (&(*self.tail.0).key, &mut (*self.tail.0).value) };
- self.tail = self.tail.prev();
- self.len -= 1;
- Some((k, v))
- }
- }
- impl<K: Ord, V> IntoIterator for RBTree<K, V> {
- type Item = (K, V);
- type IntoIter = IntoIter<K, V>;
- #[inline]
- fn into_iter(mut self) -> IntoIter<K, V> {
- let iter = if self.root.is_null() {
- IntoIter {
- head: NodePtr::null(),
- tail: NodePtr::null(),
- len: self.len,
- }
- } else {
- IntoIter {
- head: self.first_child(),
- tail: self.last_child(),
- len: self.len,
- }
- };
- self.fast_clear();
- iter
- }
- }
- impl<K: Ord, V> RBTree<K, V> {
- /// Creates an empty `RBTree`.
- pub fn new() -> RBTree<K, V> {
- RBTree {
- root: NodePtr::null(),
- len: 0,
- }
- }
- /// Returns the len of `RBTree`.
- #[inline]
- pub fn len(&self) -> usize {
- self.len
- }
- /// Returns `true` if the `RBTree` is empty.
- #[inline]
- pub fn is_empty(&self) -> bool {
- self.root.is_null()
- }
- /*
- * 对红黑树的节点(x)进行左旋转
- *
- * 左旋示意图(对节点x进行左旋):
- * px px
- * / /
- * x y
- * / \ --(左旋)--> / \ #
- * lx y x ry
- * / \ / \
- * ly ry lx ly
- *
- *
- */
- #[inline]
- unsafe fn left_rotate(&mut self, mut node: NodePtr<K, V>) {
- let mut temp = node.right();
- node.set_right(temp.left());
- if !temp.left().is_null() {
- temp.left().set_parent(node.clone());
- }
- temp.set_parent(node.parent());
- if node == self.root {
- self.root = temp.clone();
- } else if node == node.parent().left() {
- node.parent().set_left(temp.clone());
- } else {
- node.parent().set_right(temp.clone());
- }
- temp.set_left(node.clone());
- node.set_parent(temp.clone());
- }
- /*
- * 对红黑树的节点(y)进行右旋转
- *
- * 右旋示意图(对节点y进行左旋):
- * py py
- * / /
- * y x
- * / \ --(右旋)--> / \ #
- * x ry lx y
- * / \ / \ #
- * lx rx rx ry
- *
- */
- #[inline]
- unsafe fn right_rotate(&mut self, mut node: NodePtr<K, V>) {
- let mut temp = node.left();
- node.set_left(temp.right());
- if !temp.right().is_null() {
- temp.right().set_parent(node.clone());
- }
- temp.set_parent(node.parent());
- if node == self.root {
- self.root = temp.clone();
- } else if node == node.parent().right() {
- node.parent().set_right(temp.clone());
- } else {
- node.parent().set_left(temp.clone());
- }
- temp.set_right(node.clone());
- node.set_parent(temp.clone());
- }
- /// replace value if key exist, if not exist insert it.
- /// # Examples
- /// ```
- /// use rbtree::RBTree;
- /// let mut m = RBTree::new();
- /// assert_eq!(m.len(), 0);
- /// m.insert(2, 4);
- /// assert_eq!(m.len(), 1);
- /// assert_eq!(m.replace_or_insert(2, 6).unwrap(), 4);
- /// assert_eq!(m.len(), 1);
- /// assert_eq!(*m.get(&2).unwrap(), 6);
- /// ```
- #[inline]
- pub fn replace_or_insert(&mut self, k: K, mut v: V) -> Option<V> {
- let node = self.find_node(&k);
- if node.is_null() {
- self.insert(k, v);
- return None;
- }
- unsafe {
- mem::swap(&mut v, &mut (*node.0).value);
- }
- Some(v)
- }
- #[inline]
- unsafe fn insert_fixup(&mut self, mut node: NodePtr<K, V>) {
- let mut parent;
- let mut gparent;
- while node.parent().is_red_color() {
- parent = node.parent();
- gparent = parent.parent();
- //若“父节点”是“祖父节点的左孩子”
- if parent == gparent.left() {
- // Case 1条件:叔叔节点是红色
- let mut uncle = gparent.right();
- if !uncle.is_null() && uncle.is_red_color() {
- uncle.set_black_color();
- parent.set_black_color();
- gparent.set_red_color();
- node = gparent;
- continue;
- }
- // Case 2条件:叔叔是黑色,且当前节点是右孩子
- if parent.right() == node {
- self.left_rotate(parent);
- let temp = parent;
- parent = node;
- node = temp;
- }
- // Case 3条件:叔叔是黑色,且当前节点是左孩子。
- parent.set_black_color();
- gparent.set_red_color();
- self.right_rotate(gparent);
- } else {
- // Case 1条件:叔叔节点是红色
- let mut uncle = gparent.left();
- if !uncle.is_null() && uncle.is_red_color() {
- uncle.set_black_color();
- parent.set_black_color();
- gparent.set_red_color();
- node = gparent;
- continue;
- }
- // Case 2条件:叔叔是黑色,且当前节点是右孩子
- if parent.left() == node {
- self.right_rotate(parent);
- let temp = parent;
- parent = node;
- node = temp;
- }
- // Case 3条件:叔叔是黑色,且当前节点是左孩子。
- parent.set_black_color();
- gparent.set_red_color();
- self.left_rotate(gparent);
- }
- }
- self.root.set_black_color();
- }
- #[inline]
- pub fn insert(&mut self, k: K, v: V) {
- self.len += 1;
- let mut node = NodePtr::new(k, v);
- let mut y = NodePtr::null();
- let mut x = self.root;
- while !x.is_null() {
- y = x;
- match node.cmp(&&mut x) {
- Ordering::Less => {
- x = x.left();
- }
- _ => {
- x = x.right();
- }
- };
- }
- node.set_parent(y);
- if y.is_null() {
- self.root = node;
- } else {
- match node.cmp(&&mut y) {
- Ordering::Less => {
- y.set_left(node);
- }
- _ => {
- y.set_right(node);
- }
- };
- }
- node.set_red_color();
- unsafe {
- self.insert_fixup(node);
- }
- }
- #[inline]
- fn find_node(&self, k: &K) -> NodePtr<K, V> {
- if self.root.is_null() {
- return NodePtr::null();
- }
- let mut temp = &self.root;
- unsafe {
- loop {
- let next = match k.cmp(&(*temp.0).key) {
- Ordering::Less => &mut (*temp.0).left,
- Ordering::Greater => &mut (*temp.0).right,
- Ordering::Equal => return *temp,
- };
- if next.is_null() {
- break;
- }
- temp = next;
- }
- }
- NodePtr::null()
- }
- #[inline]
- fn first_child(&self) -> NodePtr<K, V> {
- if self.root.is_null() {
- NodePtr::null()
- } else {
- let mut temp = self.root;
- while !temp.left().is_null() {
- temp = temp.left();
- }
- return temp;
- }
- }
- #[inline]
- fn last_child(&self) -> NodePtr<K, V> {
- if self.root.is_null() {
- NodePtr::null()
- } else {
- let mut temp = self.root;
- while !temp.right().is_null() {
- temp = temp.right();
- }
- return temp;
- }
- }
- #[inline]
- pub fn get_first(&self) -> Option<(&K, &V)> {
- let first = self.first_child();
- if first.is_null() {
- return None;
- }
- unsafe { Some((&(*first.0).key, &(*first.0).value)) }
- }
- #[inline]
- pub fn get_last(&self) -> Option<(&K, &V)> {
- let last = self.last_child();
- if last.is_null() {
- return None;
- }
- unsafe { Some((&(*last.0).key, &(*last.0).value)) }
- }
- #[inline]
- pub fn pop_first(&mut self) -> Option<(K, V)> {
- let first = self.first_child();
- if first.is_null() {
- return None;
- }
- unsafe { Some(self.delete(first)) }
- }
- #[inline]
- pub fn pop_last(&mut self) -> Option<(K, V)> {
- let last = self.last_child();
- if last.is_null() {
- return None;
- }
- unsafe { Some(self.delete(last)) }
- }
- #[inline]
- pub fn get_first_mut(&mut self) -> Option<(&K, &mut V)> {
- let first = self.first_child();
- if first.is_null() {
- return None;
- }
- unsafe { Some((&(*first.0).key, &mut (*first.0).value)) }
- }
- #[inline]
- pub fn get_last_mut(&mut self) -> Option<(&K, &mut V)> {
- let last = self.last_child();
- if last.is_null() {
- return None;
- }
- unsafe { Some((&(*last.0).key, &mut (*last.0).value)) }
- }
- #[inline]
- pub fn get(&self, k: &K) -> Option<&V> {
- let node = self.find_node(k);
- if node.is_null() {
- return None;
- }
- unsafe { Some(&(*node.0).value) }
- }
- #[inline]
- pub fn get_mut(&mut self, k: &K) -> Option<&mut V> {
- let node = self.find_node(k);
- if node.is_null() {
- return None;
- }
- unsafe { Some(&mut (*node.0).value) }
- }
- #[inline]
- pub fn contains_key(&self, k: &K) -> bool {
- let node = self.find_node(k);
- if node.is_null() {
- return false;
- }
- true
- }
- #[inline]
- fn clear_recurse(&mut self, current: NodePtr<K, V>) {
- if !current.is_null() {
- unsafe {
- self.clear_recurse(current.left());
- self.clear_recurse(current.right());
- drop(Box::from_raw(current.0));
- }
- }
- }
- #[inline]
- pub fn clear(&mut self) {
- let root = self.root;
- self.root = NodePtr::null();
- self.clear_recurse(root);
- }
- /// Empties the `RBTree` without freeing objects in it.
- #[inline]
- fn fast_clear(&mut self) {
- self.root = NodePtr::null();
- }
- #[inline]
- pub fn remove(&mut self, k: &K) -> Option<V> {
- let node = self.find_node(k);
- if node.is_null() {
- return None;
- }
- unsafe { Some(self.delete(node).1) }
- }
- #[inline]
- unsafe fn delete_fixup(&mut self, mut node: NodePtr<K, V>, mut parent: NodePtr<K, V>) {
- let mut other;
- while node != self.root && node.is_black_color() {
- if parent.left() == node {
- other = parent.right();
- //x的兄弟w是红色的
- if other.is_red_color() {
- other.set_black_color();
- parent.set_red_color();
- self.left_rotate(parent);
- other = parent.right();
- }
- //x的兄弟w是黑色,且w的俩个孩子也都是黑色的
- if other.left().is_black_color() && other.right().is_black_color() {
- other.set_red_color();
- node = parent;
- parent = node.parent();
- } else {
- //x的兄弟w是黑色的,并且w的左孩子是红色,右孩子为黑色。
- if other.right().is_black_color() {
- other.left().set_black_color();
- other.set_red_color();
- self.right_rotate(other);
- other = parent.right();
- }
- //x的兄弟w是黑色的;并且w的右孩子是红色的,左孩子任意颜色。
- other.set_color(parent.get_color());
- parent.set_black_color();
- other.right().set_black_color();
- self.left_rotate(parent);
- node = self.root;
- break;
- }
- } else {
- other = parent.left();
- //x的兄弟w是红色的
- if other.is_red_color() {
- other.set_black_color();
- parent.set_red_color();
- self.right_rotate(parent);
- other = parent.left();
- }
- //x的兄弟w是黑色,且w的俩个孩子也都是黑色的
- if other.left().is_black_color() && other.right().is_black_color() {
- other.set_red_color();
- node = parent;
- parent = node.parent();
- } else {
- //x的兄弟w是黑色的,并且w的左孩子是红色,右孩子为黑色。
- if other.left().is_black_color() {
- other.right().set_black_color();
- other.set_red_color();
- self.left_rotate(other);
- other = parent.left();
- }
- //x的兄弟w是黑色的;并且w的右孩子是红色的,左孩子任意颜色。
- other.set_color(parent.get_color());
- parent.set_black_color();
- other.left().set_black_color();
- self.right_rotate(parent);
- node = self.root;
- break;
- }
- }
- }
- node.set_black_color();
- }
- #[inline]
- unsafe fn delete(&mut self, node: NodePtr<K, V>) -> (K, V) {
- let mut child;
- let mut parent;
- let color;
- self.len -= 1;
- // 被删除节点的"左右孩子都不为空"的情况。
- if !node.left().is_null() && !node.right().is_null() {
- // 被删节点的后继节点。(称为"取代节点")
- // 用它来取代"被删节点"的位置,然后再将"被删节点"去掉。
- let mut replace = node.right().min_node();
- if node == self.root {
- self.root = replace;
- } else {
- if node.parent().left() == node {
- node.parent().set_left(replace);
- } else {
- node.parent().set_right(replace);
- }
- }
- // child是"取代节点"的右孩子,也是需要"调整的节点"。
- // "取代节点"肯定不存在左孩子!因为它是一个后继节点。
- child = replace.right();
- parent = replace.parent();
- color = replace.get_color();
- if parent == node {
- parent = replace;
- } else {
- if !child.is_null() {
- child.set_parent(parent);
- }
- parent.set_left(child);
- replace.set_right(node.right());
- node.right().set_parent(replace);
- }
- replace.set_parent(node.parent());
- replace.set_color(node.get_color());
- replace.set_left(node.left());
- node.left().set_parent(replace);
- if color == Color::Black {
- self.delete_fixup(child, parent);
- }
- let obj = Box::from_raw(node.0);
- return obj.pair();
- }
- if !node.left().is_null() {
- child = node.left();
- } else {
- child = node.right();
- }
- parent = node.parent();
- color = node.get_color();
- if !child.is_null() {
- child.set_parent(parent);
- }
- if self.root == node {
- self.root = child
- } else {
- if parent.left() == node {
- parent.set_left(child);
- } else {
- parent.set_right(child);
- }
- }
- if color == Color::Black {
- self.delete_fixup(child, parent);
- }
- let obj = Box::from_raw(node.0);
- return obj.pair();
- }
- /// Return the keys iter
- #[inline]
- pub fn keys(&self) -> Keys<K, V> {
- Keys { inner: self.iter() }
- }
- /// Return the value iter
- #[inline]
- pub fn values(&self) -> Values<K, V> {
- Values { inner: self.iter() }
- }
- /// Return the value iter mut
- #[inline]
- pub fn values_mut(&mut self) -> ValuesMut<K, V> {
- ValuesMut { inner: self.iter_mut() }
- }
- /// Return the key and value iter
- #[inline]
- pub fn iter(&self) -> Iter<K, V> {
- Iter {
- head: self.first_child(),
- tail: self.last_child(),
- len: self.len,
- _marker: marker::PhantomData,
- }
- }
- /// Return the key and mut value iter
- #[inline]
- pub fn iter_mut(&mut self) -> IterMut<K, V> {
- IterMut {
- head: self.first_child(),
- tail: self.last_child(),
- len: self.len,
- _marker: marker::PhantomData,
- }
- }
- }
- mod tests {
- #[test]
- fn test_insert() {
- let mut m = RBTree::new();
- assert_eq!(m.len(), 0);
- m.insert(1, 2);
- assert_eq!(m.len(), 1);
- m.insert(2, 4);
- assert_eq!(m.len(), 2);
- m.insert(2, 6);
- assert_eq!(m.len(), 3);
- assert_eq!(*m.get(&1).unwrap(), 2);
- assert_eq!(*m.get(&2).unwrap(), 4);
- assert_eq!(*m.get(&2).unwrap(), 4);
- }
- #[test]
- fn test_replace() {
- let mut m = RBTree::new();
- assert_eq!(m.len(), 0);
- m.insert(2, 4);
- assert_eq!(m.len(), 1);
- assert_eq!(m.replace_or_insert(2, 6).unwrap(), 4);
- assert_eq!(m.len(), 1);
- assert_eq!(*m.get(&2).unwrap(), 6);
- }
- #[test]
- fn test_clone() {
- let mut m = RBTree::new();
- assert_eq!(m.len(), 0);
- m.insert(1, 2);
- assert_eq!(m.len(), 1);
- m.insert(2, 4);
- assert_eq!(m.len(), 2);
- let m2 = m.clone();
- m.clear();
- assert_eq!(*m2.get(&1).unwrap(), 2);
- assert_eq!(*m2.get(&2).unwrap(), 4);
- assert_eq!(m2.len(), 2);
- }
- #[test]
- fn test_empty_remove() {
- let mut m: RBTree<isize, bool> = RBTree::new();
- assert_eq!(m.remove(&0), None);
- }
- #[test]
- fn test_empty_iter() {
- let mut m: RBTree<isize, bool> = RBTree::new();
- assert_eq!(m.iter().next(), None);
- assert_eq!(m.iter_mut().next(), None);
- assert_eq!(m.len(), 0);
- assert!(m.is_empty());
- assert_eq!(m.into_iter().next(), None);
- }
- #[test]
- fn test_lots_of_insertions() {
- let mut m = RBTree::new();
- // Try this a few times to make sure we never screw up the hashmap's
- // internal state.
- for _ in 0..10 {
- assert!(m.is_empty());
- for i in 1..101 {
- m.insert(i, i);
- for j in 1..i + 1 {
- let r = m.get(&j);
- assert_eq!(r, Some(&j));
- }
- for j in i + 1..101 {
- let r = m.get(&j);
- assert_eq!(r, None);
- }
- }
- for i in 101..201 {
- assert!(!m.contains_key(&i));
- }
- // remove forwards
- for i in 1..101 {
- assert!(m.remove(&i).is_some());
- for j in 1..i + 1 {
- assert!(!m.contains_key(&j));
- }
- for j in i + 1..101 {
- assert!(m.contains_key(&j));
- }
- }
- for i in 1..101 {
- assert!(!m.contains_key(&i));
- }
- for i in 1..101 {
- m.insert(i, i);
- }
- // remove backwards
- for i in (1..101).rev() {
- assert!(m.remove(&i).is_some());
- for j in i..101 {
- assert!(!m.contains_key(&j));
- }
- for j in 1..i {
- assert!(m.contains_key(&j));
- }
- }
- }
- }
- #[test]
- fn test_find_mut() {
- let mut m = RBTree::new();
- m.insert(1, 12);
- m.insert(2, 8);
- m.insert(5, 14);
- let new = 100;
- match m.get_mut(&5) {
- None => panic!(),
- Some(x) => *x = new,
- }
- assert_eq!(m.get(&5), Some(&new));
- }
- #[test]
- fn test_remove() {
- let mut m = RBTree::new();
- m.insert(1, 2);
- assert_eq!(*m.get(&1).unwrap(), 2);
- m.insert(5, 3);
- assert_eq!(*m.get(&5).unwrap(), 3);
- m.insert(9, 4);
- assert_eq!(*m.get(&1).unwrap(), 2);
- assert_eq!(*m.get(&5).unwrap(), 3);
- assert_eq!(*m.get(&9).unwrap(), 4);
- assert_eq!(m.remove(&1).unwrap(), 2);
- assert_eq!(m.remove(&5).unwrap(), 3);
- assert_eq!(m.remove(&9).unwrap(), 4);
- assert_eq!(m.len(), 0);
- }
- #[test]
- fn test_is_empty() {
- let mut m = RBTree::new();
- m.insert(1, 2);
- assert!(!m.is_empty());
- assert!(m.remove(&1).is_some());
- assert!(m.is_empty());
- }
- #[test]
- fn test_pop() {
- let mut m = RBTree::new();
- m.insert(2, 4);
- m.insert(1, 2);
- m.insert(3, 6);
- assert_eq!(m.len(), 3);
- assert_eq!(m.pop_first(), Some((1, 2)));
- assert_eq!(m.len(), 2);
- assert_eq!(m.pop_last(), Some((3, 6)));
- assert_eq!(m.len(), 1);
- assert_eq!(m.get_first(), Some((&2, &4)));
- assert_eq!(m.get_last(), Some((&2, &4)));
- }
- #[test]
- fn test_iterate() {
- let mut m = RBTree::new();
- for i in 0..32 {
- m.insert(i, i * 2);
- }
- assert_eq!(m.len(), 32);
- let mut observed: u32 = 0;
- for (k, v) in m.iter() {
- assert_eq!(*v, *k * 2);
- observed |= 1 << *k;
- }
- assert_eq!(observed, 0xFFFF_FFFF);
- }
- #[test]
- fn test_keys() {
- let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
- let map: RBTree<_, _> = vec.into_iter().collect();
- let keys: Vec<_> = map.keys().cloned().collect();
- assert_eq!(keys.len(), 3);
- assert!(keys.contains(&1));
- assert!(keys.contains(&2));
- assert!(keys.contains(&3));
- }
- #[test]
- fn test_values() {
- let vec = vec![(1, 'a'), (2, 'b'), (3, 'c')];
- let map: RBTree<_, _> = vec.into_iter().collect();
- let values: Vec<_> = map.values().cloned().collect();
- assert_eq!(values.len(), 3);
- assert!(values.contains(&'a'));
- assert!(values.contains(&'b'));
- assert!(values.contains(&'c'));
- }
- #[test]
- fn test_values_mut() {
- let vec = vec![(1, 1), (2, 2), (3, 3)];
- let mut map: RBTree<_, _> = vec.into_iter().collect();
- for value in map.values_mut() {
- *value = (*value) * 2
- }
- let values: Vec<_> = map.values().cloned().collect();
- assert_eq!(values.len(), 3);
- assert!(values.contains(&2));
- assert!(values.contains(&4));
- assert!(values.contains(&6));
- }
- #[test]
- fn test_find() {
- let mut m = RBTree::new();
- assert!(m.get(&1).is_none());
- m.insert(1, 2);
- match m.get(&1) {
- None => panic!(),
- Some(v) => assert_eq!(*v, 2),
- }
- }
- #[test]
- fn test_eq() {
- let mut m1 = RBTree::new();
- m1.insert(1, 2);
- m1.insert(2, 3);
- m1.insert(3, 4);
- let mut m2 = RBTree::new();
- m2.insert(1, 2);
- m2.insert(2, 3);
- assert!(m1 != m2);
- m2.insert(3, 4);
- assert_eq!(m1, m2);
- }
- #[test]
- fn test_show() {
- let mut map = RBTree::new();
- let empty: RBTree<i32, i32> = RBTree::new();
- map.insert(1, 2);
- map.insert(3, 4);
- let map_str = format!("{:?}", map);
- assert!(map_str == "{1: 2, 3: 4}" || map_str == "{3: 4, 1: 2}");
- assert_eq!(format!("{:?}", empty), "{}");
- }
- #[test]
- fn test_from_iter() {
- let xs = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5), (6, 6)];
- let map: RBTree<_, _> = xs.iter().cloned().collect();
- for &(k, v) in &xs {
- assert_eq!(map.get(&k), Some(&v));
- }
- }
- #[test]
- fn test_size_hint() {
- let xs = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5), (6, 6)];
- let map: RBTree<_, _> = xs.iter().cloned().collect();
- let mut iter = map.iter();
- for _ in iter.by_ref().take(3) {}
- assert_eq!(iter.size_hint(), (3, Some(3)));
- }
- #[test]
- fn test_iter_len() {
- let xs = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5), (6, 6)];
- let map: RBTree<_, _> = xs.iter().cloned().collect();
- let mut iter = map.iter();
- for _ in iter.by_ref().take(3) {}
- assert_eq!(iter.count(), 3);
- }
- #[test]
- fn test_mut_size_hint() {
- let xs = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5), (6, 6)];
- let mut map: RBTree<_, _> = xs.iter().cloned().collect();
- let mut iter = map.iter_mut();
- for _ in iter.by_ref().take(3) {}
- assert_eq!(iter.size_hint(), (3, Some(3)));
- }
- #[test]
- fn test_iter_mut_len() {
- let xs = [(1, 1), (2, 2), (3, 3), (4, 4), (5, 5), (6, 6)];
- let mut map: RBTree<_, _> = xs.iter().cloned().collect();
- let mut iter = map.iter_mut();
- for _ in iter.by_ref().take(3) {}
- assert_eq!(iter.count(), 3);
- }
- #[test]
- fn test_index() {
- let mut map = RBTree::new();
- map.insert(1, 2);
- map.insert(2, 1);
- map.insert(3, 4);
- assert_eq!(map[&2], 1);
- }
- #[test]
- #[should_panic]
- fn test_index_nonexistent() {
- let mut map = RBTree::new();
- map.insert(1, 2);
- map.insert(2, 1);
- map.insert(3, 4);
- map[&4];
- }
- #[test]
- fn test_extend_iter() {
- let mut a = RBTree::new();
- a.insert(1, "one");
- let mut b = RBTree::new();
- b.insert(2, "two");
- b.insert(3, "three");
- a.extend(b.into_iter());
- assert_eq!(a.len(), 3);
- assert_eq!(a[&1], "one");
- assert_eq!(a[&2], "two");
- assert_eq!(a[&3], "three");
- }
- }
|