summaryrefslogtreecommitdiffstats
path: root/library/core/src/ops/index_range.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:20:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:20:39 +0000
commit1376c5a617be5c25655d0d7cb63e3beaa5a6e026 (patch)
tree3bb8d61aee02bc7a15eab3f36e3b921afc2075d0 /library/core/src/ops/index_range.rs
parentReleasing progress-linux version 1.69.0+dfsg1-1~progress7.99u1. (diff)
downloadrustc-1376c5a617be5c25655d0d7cb63e3beaa5a6e026.tar.xz
rustc-1376c5a617be5c25655d0d7cb63e3beaa5a6e026.zip
Merging upstream version 1.70.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'library/core/src/ops/index_range.rs')
-rw-r--r--library/core/src/ops/index_range.rs15
1 files changed, 7 insertions, 8 deletions
diff --git a/library/core/src/ops/index_range.rs b/library/core/src/ops/index_range.rs
index 3e06776d2..265022a39 100644
--- a/library/core/src/ops/index_range.rs
+++ b/library/core/src/ops/index_range.rs
@@ -1,5 +1,6 @@
use crate::intrinsics::{assert_unsafe_precondition, unchecked_add, unchecked_sub};
use crate::iter::{FusedIterator, TrustedLen};
+use crate::num::NonZeroUsize;
/// Like a `Range<usize>`, but with a safety invariant that `start <= end`.
///
@@ -132,10 +133,9 @@ impl Iterator for IndexRange {
}
#[inline]
- fn advance_by(&mut self, n: usize) -> Result<(), usize> {
- let original_len = self.len();
- self.take_prefix(n);
- if n > original_len { Err(original_len) } else { Ok(()) }
+ fn advance_by(&mut self, n: usize) -> Result<(), NonZeroUsize> {
+ let taken = self.take_prefix(n);
+ NonZeroUsize::new(n - taken.len()).map_or(Ok(()), Err)
}
}
@@ -151,10 +151,9 @@ impl DoubleEndedIterator for IndexRange {
}
#[inline]
- fn advance_back_by(&mut self, n: usize) -> Result<(), usize> {
- let original_len = self.len();
- self.take_suffix(n);
- if n > original_len { Err(original_len) } else { Ok(()) }
+ fn advance_back_by(&mut self, n: usize) -> Result<(), NonZeroUsize> {
+ let taken = self.take_suffix(n);
+ NonZeroUsize::new(n - taken.len()).map_or(Ok(()), Err)
}
}