summaryrefslogtreecommitdiff
path: root/vendor/itertools/src/repeatn.rs
diff options
context:
space:
mode:
authormo khan <mo@mokhan.ca>2025-07-02 18:36:06 -0600
committermo khan <mo@mokhan.ca>2025-07-02 18:36:06 -0600
commit8cdfa445d6629ffef4cb84967ff7017654045bc2 (patch)
tree22f0b0907c024c78d26a731e2e1f5219407d8102 /vendor/itertools/src/repeatn.rs
parent4351c74c7c5f97156bc94d3a8549b9940ac80e3f (diff)
chore: add vendor directory
Diffstat (limited to 'vendor/itertools/src/repeatn.rs')
-rw-r--r--vendor/itertools/src/repeatn.rs83
1 files changed, 83 insertions, 0 deletions
diff --git a/vendor/itertools/src/repeatn.rs b/vendor/itertools/src/repeatn.rs
new file mode 100644
index 00000000..d86ad9fa
--- /dev/null
+++ b/vendor/itertools/src/repeatn.rs
@@ -0,0 +1,83 @@
+use std::iter::FusedIterator;
+
+/// An iterator that produces *n* repetitions of an element.
+///
+/// See [`repeat_n()`](crate::repeat_n) for more information.
+#[must_use = "iterators are lazy and do nothing unless consumed"]
+#[derive(Clone, Debug)]
+pub struct RepeatN<A> {
+ pub(crate) elt: Option<A>,
+ n: usize,
+}
+
+/// Create an iterator that produces `n` repetitions of `element`.
+pub fn repeat_n<A>(element: A, n: usize) -> RepeatN<A>
+where
+ A: Clone,
+{
+ if n == 0 {
+ RepeatN { elt: None, n }
+ } else {
+ RepeatN {
+ elt: Some(element),
+ n,
+ }
+ }
+}
+
+impl<A> Iterator for RepeatN<A>
+where
+ A: Clone,
+{
+ type Item = A;
+
+ fn next(&mut self) -> Option<Self::Item> {
+ if self.n > 1 {
+ self.n -= 1;
+ self.elt.as_ref().cloned()
+ } else {
+ self.n = 0;
+ self.elt.take()
+ }
+ }
+
+ fn size_hint(&self) -> (usize, Option<usize>) {
+ (self.n, Some(self.n))
+ }
+
+ fn fold<B, F>(self, mut init: B, mut f: F) -> B
+ where
+ F: FnMut(B, Self::Item) -> B,
+ {
+ match self {
+ Self { elt: Some(elt), n } => {
+ debug_assert!(n > 0);
+ init = (1..n).map(|_| elt.clone()).fold(init, &mut f);
+ f(init, elt)
+ }
+ _ => init,
+ }
+ }
+}
+
+impl<A> DoubleEndedIterator for RepeatN<A>
+where
+ A: Clone,
+{
+ #[inline]
+ fn next_back(&mut self) -> Option<Self::Item> {
+ self.next()
+ }
+
+ #[inline]
+ fn rfold<B, F>(self, init: B, f: F) -> B
+ where
+ F: FnMut(B, Self::Item) -> B,
+ {
+ self.fold(init, f)
+ }
+}
+
+impl<A> ExactSizeIterator for RepeatN<A> where A: Clone {}
+
+impl<A> FusedIterator for RepeatN<A> where A: Clone {}