From 1b32c1efb345ea979da091aba320493447703ce9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Renault?= Date: Mon, 23 Sep 2024 14:29:19 +0200 Subject: [PATCH] Update the insert to push when possible --- roaring/src/bitmap/inherent.rs | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/roaring/src/bitmap/inherent.rs b/roaring/src/bitmap/inherent.rs index b2919b4c..499b5d23 100644 --- a/roaring/src/bitmap/inherent.rs +++ b/roaring/src/bitmap/inherent.rs @@ -50,15 +50,20 @@ impl RoaringBitmap { /// ``` #[inline] pub fn insert(&mut self, value: u32) -> bool { - let (key, index) = util::split(value); - let container = match self.containers.binary_search_by_key(&key, |c| c.key) { - Ok(loc) => &mut self.containers[loc], - Err(loc) => { - self.containers.insert(loc, Container::new(key)); - &mut self.containers[loc] - } - }; - container.insert(index) + if self.max().map_or(true, |max| value > max) { + self.push_unchecked(value); + true + } else { + let (key, index) = util::split(value); + let container = match self.containers.binary_search_by_key(&key, |c| c.key) { + Ok(loc) => &mut self.containers[loc], + Err(loc) => { + self.containers.insert(loc, Container::new(key)); + &mut self.containers[loc] + } + }; + container.insert(index) + } } /// Search for the specific container by the given key.