diff options
Diffstat (limited to 'src/duplicates_impl.rs')
-rw-r--r-- | src/duplicates_impl.rs | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/src/duplicates_impl.rs b/src/duplicates_impl.rs index 42049df..640d481 100644 --- a/src/duplicates_impl.rs +++ b/src/duplicates_impl.rs @@ -84,13 +84,18 @@ mod private { #[inline] fn size_hint(&self) -> (usize, Option<usize>) { let (_, hi) = self.iter.size_hint(); - // There are `hi` number of items left in the base iterator. In the best case scenario, - // these items are exactly the same as the ones pending (i.e items seen exactly once so - // far), plus (hi - pending) / 2 pairs of never seen before items. let hi = hi.map(|hi| { - let max_pending = std::cmp::min(self.meta.pending, hi); - let max_new = std::cmp::max(hi - self.meta.pending, 0) / 2; - max_pending + max_new + if hi <= self.meta.pending { + // fewer or equally many iter-remaining elements than pending elements + // => at most, each iter-remaining element is matched + hi + } else { + // fewer pending elements than iter-remaining elements + // => at most: + // * each pending element is matched + // * the other iter-remaining elements come in pairs + self.meta.pending + (hi - self.meta.pending) / 2 + } }); // The lower bound is always 0 since we might only get unique items from now on (0, hi) @@ -117,6 +122,7 @@ mod private { } /// Apply the identity function to elements before checking them for equality. + #[derive(Debug)] pub struct ById; impl<V> KeyMethod<V, V> for ById { type Container = JustValue<V>; @@ -128,6 +134,9 @@ mod private { /// Apply a user-supplied function to elements before checking them for equality. pub struct ByFn<F>(pub(crate) F); + impl<F> fmt::Debug for ByFn<F> { + debug_fmt_fields!(ByFn,); + } impl<K, V, F> KeyMethod<K, V> for ByFn<F> where F: FnMut(&V) -> K, @@ -147,6 +156,7 @@ mod private { fn value(self) -> V; } + #[derive(Debug)] pub struct KeyValue<K, V>(K, V); impl<K, V> KeyXorValue<K, V> for KeyValue<K, V> { fn key_ref(&self) -> &K { @@ -160,6 +170,7 @@ mod private { } } + #[derive(Debug)] pub struct JustValue<V>(V); impl<V> KeyXorValue<V, V> for JustValue<V> { fn key_ref(&self) -> &V { |