Struct static_rc::rcref::StaticRcRef [−][src]
pub struct StaticRcRef<'a, T: ?Sized, const NUM: usize, const DEN: usize> { /* fields omitted */ }
A compile-time reference-counted pointer.
The inherent methods of StaticRc
are all associated functions to avoid conflicts with the the methods of the
inner type T
which are brought into scope by the Deref
implementation.
The parameters NUM
and DEN
DENote the ratio (NUM / DEN
) of ownership of the pointer:
- The ratio is always in the (0, 1] interval, that is:
NUM > 0
andNUM <= DEN
. - When the ratio is equal to 1, that is when
NUM == DEN
, then the instance has full ownership of the pointee and extra capabilities are unlocked.
Implementations
impl<'a, T: ?Sized, const N: usize> StaticRcRef<'a, T, N, N>
[src]
impl<'a, T: ?Sized, const N: usize> StaticRcRef<'a, T, N, N>
[src]pub fn new(value: &'a mut T) -> Self where
(): Sized,
[src]
pub fn new(value: &'a mut T) -> Self where
(): Sized,
[src]Constructs a new StaticRcRef<'a, T, N, N>
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let rc = Full::new(&mut value); assert_eq!(42, *rc);
pub fn pin(value: &'a mut T) -> Pin<Self> where
(): Sized,
[src]
pub fn pin(value: &'a mut T) -> Pin<Self> where
(): Sized,
[src]Constructs a new Pin<StaticRcRef<'a, T, N, N>>
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let rc = Full::pin(&mut value); assert_eq!(42, *rc);
pub fn into_inner(this: Self) -> &'a mut T
[src]
pub fn into_inner(this: Self) -> &'a mut T
[src]Returns the inner value.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let rc = Full::new(&mut value); let inner: &mut i32 = Full::into_inner(rc); assert_eq!(42, *inner);
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> StaticRcRef<'a, T, NUM, DEN>
[src]pub fn into_raw(this: Self) -> NonNull<T>
[src]
pub fn into_raw(this: Self) -> NonNull<T>
[src]Consumes the StaticRcRef
, returning the wrapped pointer.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let rc = Full::new(&mut value); let pointer = Full::into_raw(rc); assert_eq!(&mut value as *mut _, pointer.as_ptr());
pub fn as_ptr(this: &Self) -> NonNull<T>
[src]
pub fn as_ptr(this: &Self) -> NonNull<T>
[src]Provides a raw pointer to the data.
StaticRcRef
is not consumed or affected in any way, the pointer is valid as long as the original value is.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let pointer = &mut value as *mut _; let rc = Full::new(&mut value); let other_pointer = Full::as_ptr(&rc); assert_eq!(pointer, other_pointer.as_ptr());
pub fn get_ref(this: &Self) -> &T
[src]
pub fn get_ref(this: &Self) -> &T
[src]Provides a reference to the data.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 1, 1>; let mut value = 42; let rc = Full::new(&mut value); let r = Full::get_ref(&rc); assert_eq!(42, *r);
pub unsafe fn from_raw(pointer: NonNull<T>) -> Self where
(): Sized,
[src]
pub unsafe fn from_raw(pointer: NonNull<T>) -> Self where
(): Sized,
[src]Constructs a StaticRcRef<'a, T, NUM, DEN>
from a raw pointer.
The raw pointer must have been previously returned by a call to StaticRcRef<'a, U, N, D>::into_raw
:
- If
U
is different fromT
, then specific restrictions on size and alignment apply. Seemem::transmute
for the restrictions applying to transmuting references. - If
N / D
is different fromNUM / DEN
, then specific restrictions apply. The user is responsible for ensuring proper management of the ratio of shares, and ultimately that the value is not dropped twice.
pub fn ptr_eq<const N: usize, const D: usize>(
this: &Self,
other: &StaticRcRef<'a, T, N, D>
) -> bool
[src]
pub fn ptr_eq<const N: usize, const D: usize>(
this: &Self,
other: &StaticRcRef<'a, T, N, D>
) -> bool
[src]Returns true if the two StaticRcRef
point to the same allocation.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let (one, two) = Full::split::<1, 1>(rc); assert!(StaticRcRef::ptr_eq(&one, &two));
pub fn adjust<const N: usize, const D: usize>(
this: Self
) -> StaticRcRef<'a, T, N, D>ⓘNotable traits for StaticRcRef<'a, I, N, N>
impl<'a, I: Iterator + ?Sized, const N: usize> Iterator for StaticRcRef<'a, I, N, N> type Item = I::Item;impl<'a, F: ?Sized + Future + Unpin, const N: usize> Future for StaticRcRef<'a, F, N, N> type Output = F::Output;
where
(): Sized,
((), ()): Sized,
[src]
pub fn adjust<const N: usize, const D: usize>(
this: Self
) -> StaticRcRef<'a, T, N, D>ⓘNotable traits for StaticRcRef<'a, I, N, N>
impl<'a, I: Iterator + ?Sized, const N: usize> Iterator for StaticRcRef<'a, I, N, N> type Item = I::Item;impl<'a, F: ?Sized + Future + Unpin, const N: usize> Future for StaticRcRef<'a, F, N, N> type Output = F::Output;
where
(): Sized,
((), ()): Sized,
[src]Adjusts the NUMerator and DENumerator of the ratio of the instance, preserving the ratio.
Panics
If the compile-time-ratio feature is not used, and the ratio is not preserved; that is N / D <> NUM / DEN
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let rc = Full::adjust::<1, 1>(rc); assert_eq!(42, *rc);
pub fn split<const A: usize, const B: usize>(
this: Self
) -> (StaticRcRef<'a, T, A, DEN>, StaticRcRef<'a, T, B, DEN>) where
(): Sized,
(): Sized,
((), ()): Sized,
[src]
pub fn split<const A: usize, const B: usize>(
this: Self
) -> (StaticRcRef<'a, T, A, DEN>, StaticRcRef<'a, T, B, DEN>) where
(): Sized,
(): Sized,
((), ()): Sized,
[src]Splits the current instance into two instances with the specified NUMerators.
Panics
If the compile-time-ratio feature is not used, and the ratio is not preserved; that is A + B <> NUM
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let (one, two) = Full::split::<1, 1>(rc); assert_eq!(42, *one); assert_eq!(42, *two);
pub fn split_array<const N: usize, const DIM: usize>(
this: Self
) -> [StaticRcRef<'a, T, N, DEN>; DIM] where
T: 'a,
((), ()): Sized,
(): Sized,
[src]
pub fn split_array<const N: usize, const DIM: usize>(
this: Self
) -> [StaticRcRef<'a, T, N, DEN>; DIM] where
T: 'a,
((), ()): Sized,
(): Sized,
[src]Splits the current instance into DIM instances with the specified Numerators.
Panics
If the compile-time-ratio feature is not used, and the ratio is not preserved; that is N * DIM <> NUM
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let array = Full::split_array::<1, 2>(rc); assert_eq!(42, *array[0]); assert_eq!(42, *array[1]);
pub fn join<const A: usize, const B: usize>(
left: StaticRcRef<'a, T, A, DEN>,
right: StaticRcRef<'a, T, B, DEN>
) -> Self
[src]
pub fn join<const A: usize, const B: usize>(
left: StaticRcRef<'a, T, A, DEN>,
right: StaticRcRef<'a, T, B, DEN>
) -> Self
[src]Joins two instances into a single instance.
Panics
If the two instances do no point to the same allocation, as determined by StaticRcRef::ptr_eq
.
If the compile-time-ratio feature is not used and the ratio is not preserved; that is A + B <> NUM
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let (one, two) = Full::split::<1, 1>(rc); let rc = Full::join(one, two); assert_eq!(42, *rc);
pub unsafe fn join_unchecked<const A: usize, const B: usize>(
left: StaticRcRef<'a, T, A, DEN>,
_right: StaticRcRef<'a, T, B, DEN>
) -> Self
[src]
pub unsafe fn join_unchecked<const A: usize, const B: usize>(
left: StaticRcRef<'a, T, A, DEN>,
_right: StaticRcRef<'a, T, B, DEN>
) -> Self
[src]Joins two instances into a single instance without checking whether they point to the same allocation.
Unless compile-time-ratio
is activated, the ratios are checked nevertheless.
Safety
The caller must guarantee that those instances point to the same allocation.
Panics
If the compile-time-ratio feature is not used and the ratio is not preserved; that is A + B <> NUM
.
In debug, if the two instances do no point to the same allocation, as determined by StaticRcRef::ptr_eq
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let (one, two) = Full::split::<1, 1>(rc); let rc = unsafe { Full::join_unchecked(one, two) }; assert_eq!(42, *rc);
pub fn join_array<const N: usize, const DIM: usize>(
array: [StaticRcRef<'a, T, N, DEN>; DIM]
) -> Self
[src]
pub fn join_array<const N: usize, const DIM: usize>(
array: [StaticRcRef<'a, T, N, DEN>; DIM]
) -> Self
[src]Joins DIM instances into a single instance.
Panics
If all instances do not point to the same allocation, as determined by StaticRcRef::ptr_eq
.
If the compile-time-ratio feature is not used and the ratio is not preserved; that is N * DIM <> NUM
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let array = Full::split_array::<1, 2>(rc); let rc = Full::join_array(array); assert_eq!(42, *rc);
pub unsafe fn join_array_unchecked<const N: usize, const DIM: usize>(
array: [StaticRcRef<'a, T, N, DEN>; DIM]
) -> Self
[src]
pub unsafe fn join_array_unchecked<const N: usize, const DIM: usize>(
array: [StaticRcRef<'a, T, N, DEN>; DIM]
) -> Self
[src]Joins DIM instances into a single instance.
Panics
If the compile-time-ratio feature is not used and the ratio is not preserved; that is N * DIM <> NUM
.
In debug, if all instances do not point to the same allocation, as determined by StaticRcRef::ptr_eq
.
Example
use static_rc::StaticRcRef; type Full<'a> = StaticRcRef<'a, i32, 2, 2>; let mut value = 42; let rc = Full::new(&mut value); let array = Full::split_array::<1, 2>(rc); let rc = unsafe { Full::join_array_unchecked(array) }; assert_eq!(42, *rc);
impl<'a, const NUM: usize, const DEN: usize> StaticRcRef<'a, dyn Any, NUM, DEN>
[src]
impl<'a, const NUM: usize, const DEN: usize> StaticRcRef<'a, dyn Any, NUM, DEN>
[src]pub fn downcast<T: Any>(self) -> Result<StaticRcRef<'a, T, NUM, DEN>, Self>
[src]
pub fn downcast<T: Any>(self) -> Result<StaticRcRef<'a, T, NUM, DEN>, Self>
[src]Attempts to downcast Self
to a concrete type.
Trait Implementations
impl<'a, T: ?Sized, const N: usize> AsMut<T> for StaticRcRef<'a, T, N, N>
[src]
impl<'a, T: ?Sized, const N: usize> AsMut<T> for StaticRcRef<'a, T, N, N>
[src]impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> AsRef<T> for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> AsRef<T> for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Borrow<T> for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Borrow<T> for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized, const N: usize> BorrowMut<T> for StaticRcRef<'a, T, N, N>
[src]
impl<'a, T: ?Sized, const N: usize> BorrowMut<T> for StaticRcRef<'a, T, N, N>
[src]fn borrow_mut(&mut self) -> &mut T
[src]
fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<'a, T: ?Sized + Debug, const NUM: usize, const DEN: usize> Debug for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized + Debug, const NUM: usize, const DEN: usize> Debug for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Deref for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Deref for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized, const N: usize> DerefMut for StaticRcRef<'a, T, N, N>
[src]
impl<'a, T: ?Sized, const N: usize> DerefMut for StaticRcRef<'a, T, N, N>
[src]impl<'a, T: ?Sized + Display, const NUM: usize, const DEN: usize> Display for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized + Display, const NUM: usize, const DEN: usize> Display for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, I: DoubleEndedIterator + ?Sized, const N: usize> DoubleEndedIterator for StaticRcRef<'a, I, N, N>
[src]
impl<'a, I: DoubleEndedIterator + ?Sized, const N: usize> DoubleEndedIterator for StaticRcRef<'a, I, N, N>
[src]fn next_back(&mut self) -> Option<I::Item>
[src]
fn next_back(&mut self) -> Option<I::Item>
[src]Removes and returns an element from the end of the iterator. Read more
fn nth_back(&mut self, n: usize) -> Option<I::Item>
[src]
fn nth_back(&mut self, n: usize) -> Option<I::Item>
[src]Returns the n
th element from the end of the iterator. Read more
fn advance_back_by(&mut self, n: usize) -> Result<(), usize>
[src]
fn advance_back_by(&mut self, n: usize) -> Result<(), usize>
[src]🔬 This is a nightly-only experimental API. (iter_advance_by
)
recently added
Advances the iterator from the back by n
elements. Read more
fn try_rfold<B, F, R>(&mut self, init: B, f: F) -> R where
F: FnMut(B, Self::Item) -> R,
R: Try<Ok = B>,
1.27.0[src]
fn try_rfold<B, F, R>(&mut self, init: B, f: F) -> R where
F: FnMut(B, Self::Item) -> R,
R: Try<Ok = B>,
1.27.0[src]This is the reverse version of Iterator::try_fold()
: it takes
elements starting from the back of the iterator. Read more
impl<'a, I: ExactSizeIterator + ?Sized, const N: usize> ExactSizeIterator for StaticRcRef<'a, I, N, N>
[src]
impl<'a, I: ExactSizeIterator + ?Sized, const N: usize> ExactSizeIterator for StaticRcRef<'a, I, N, N>
[src]impl<'a, const NUM: usize, const DEN: usize> From<StaticRcRef<'a, str, NUM, DEN>> for StaticRcRef<'a, [u8], NUM, DEN>
[src]
impl<'a, const NUM: usize, const DEN: usize> From<StaticRcRef<'a, str, NUM, DEN>> for StaticRcRef<'a, [u8], NUM, DEN>
[src]fn from(value: StaticRcRef<'a, str, NUM, DEN>) -> Self
[src]
fn from(value: StaticRcRef<'a, str, NUM, DEN>) -> Self
[src]Performs the conversion.
impl<'a, T: ?Sized + Hash, const NUM: usize, const DEN: usize> Hash for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized + Hash, const NUM: usize, const DEN: usize> Hash for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, I: Iterator + ?Sized, const N: usize> Iterator for StaticRcRef<'a, I, N, N>
[src]
impl<'a, I: Iterator + ?Sized, const N: usize> Iterator for StaticRcRef<'a, I, N, N>
[src]fn next(&mut self) -> Option<I::Item>
[src]
fn next(&mut self) -> Option<I::Item>
[src]Advances the iterator and returns the next value. Read more
fn size_hint(&self) -> (usize, Option<usize>)
[src]
fn size_hint(&self) -> (usize, Option<usize>)
[src]Returns the bounds on the remaining length of the iterator. Read more
fn nth(&mut self, n: usize) -> Option<I::Item>
[src]
fn nth(&mut self, n: usize) -> Option<I::Item>
[src]Returns the n
th element of the iterator. Read more
fn count(self) -> usize
1.0.0[src]
fn count(self) -> usize
1.0.0[src]Consumes the iterator, counting the number of iterations and returning it. Read more
fn advance_by(&mut self, n: usize) -> Result<(), usize>
[src]
fn advance_by(&mut self, n: usize) -> Result<(), usize>
[src]🔬 This is a nightly-only experimental API. (iter_advance_by
)
recently added
Advances the iterator by n
elements. Read more
fn step_by(self, step: usize) -> StepBy<Self>
1.28.0[src]
fn step_by(self, step: usize) -> StepBy<Self>
1.28.0[src]Creates an iterator starting at the same point, but stepping by the given amount at each iteration. Read more
fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter> where
U: IntoIterator<Item = Self::Item>,
1.0.0[src]
fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter> where
U: IntoIterator<Item = Self::Item>,
1.0.0[src]Takes two iterators and creates a new iterator over both in sequence. Read more
fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter> where
U: IntoIterator,
1.0.0[src]
fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter> where
U: IntoIterator,
1.0.0[src]‘Zips up’ two iterators into a single iterator of pairs. Read more
fn intersperse(self, separator: Self::Item) -> Intersperse<Self> where
Self::Item: Clone,
[src]
fn intersperse(self, separator: Self::Item) -> Intersperse<Self> where
Self::Item: Clone,
[src]🔬 This is a nightly-only experimental API. (iter_intersperse
)
recently added
Creates a new iterator which places a copy of separator
between adjacent
items of the original iterator. Read more
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G> where
G: FnMut() -> Self::Item,
[src]
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G> where
G: FnMut() -> Self::Item,
[src]🔬 This is a nightly-only experimental API. (iter_intersperse
)
recently added
Creates a new iterator which places an item generated by separator
between adjacent items of the original iterator. Read more
fn map<B, F>(self, f: F) -> Map<Self, F> where
F: FnMut(Self::Item) -> B,
1.0.0[src]
fn map<B, F>(self, f: F) -> Map<Self, F> where
F: FnMut(Self::Item) -> B,
1.0.0[src]Takes a closure and creates an iterator which calls that closure on each element. Read more
fn for_each<F>(self, f: F) where
F: FnMut(Self::Item),
1.21.0[src]
fn for_each<F>(self, f: F) where
F: FnMut(Self::Item),
1.21.0[src]Calls a closure on each element of an iterator. Read more
fn filter<P>(self, predicate: P) -> Filter<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]
fn filter<P>(self, predicate: P) -> Filter<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]Creates an iterator which uses a closure to determine if an element should be yielded. Read more
fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F> where
F: FnMut(Self::Item) -> Option<B>,
1.0.0[src]
fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F> where
F: FnMut(Self::Item) -> Option<B>,
1.0.0[src]Creates an iterator that both filters and maps. Read more
fn enumerate(self) -> Enumerate<Self>
1.0.0[src]
fn enumerate(self) -> Enumerate<Self>
1.0.0[src]Creates an iterator which gives the current iteration count as well as the next value. Read more
fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]
fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]
fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]Creates an iterator that yields elements based on a predicate. Read more
fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P> where
P: FnMut(Self::Item) -> Option<B>,
[src]
fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P> where
P: FnMut(Self::Item) -> Option<B>,
[src]🔬 This is a nightly-only experimental API. (iter_map_while
)
recently added
Creates an iterator that both yields elements based on a predicate and maps. Read more
fn skip(self, n: usize) -> Skip<Self>
1.0.0[src]
fn skip(self, n: usize) -> Skip<Self>
1.0.0[src]Creates an iterator that skips the first n
elements. Read more
fn take(self, n: usize) -> Take<Self>
1.0.0[src]
fn take(self, n: usize) -> Take<Self>
1.0.0[src]Creates an iterator that yields the first n
elements, or fewer
if the underlying iterator ends sooner. Read more
fn scan<St, B, F>(self, initial_state: St, f: F) -> Scan<Self, St, F> where
F: FnMut(&mut St, Self::Item) -> Option<B>,
1.0.0[src]
fn scan<St, B, F>(self, initial_state: St, f: F) -> Scan<Self, St, F> where
F: FnMut(&mut St, Self::Item) -> Option<B>,
1.0.0[src]fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F> where
U: IntoIterator,
F: FnMut(Self::Item) -> U,
1.0.0[src]
fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F> where
U: IntoIterator,
F: FnMut(Self::Item) -> U,
1.0.0[src]Creates an iterator that works like map, but flattens nested structure. Read more
fn flatten(self) -> Flatten<Self> where
Self::Item: IntoIterator,
1.29.0[src]
fn flatten(self) -> Flatten<Self> where
Self::Item: IntoIterator,
1.29.0[src]Creates an iterator that flattens nested structure. Read more
fn inspect<F>(self, f: F) -> Inspect<Self, F> where
F: FnMut(&Self::Item),
1.0.0[src]
fn inspect<F>(self, f: F) -> Inspect<Self, F> where
F: FnMut(&Self::Item),
1.0.0[src]Does something with each element of an iterator, passing the value on. Read more
#[must_use = "if you really need to exhaust the iterator, consider `.for_each(drop)` instead"]fn collect<B>(self) -> B where
B: FromIterator<Self::Item>,
1.0.0[src]
#[must_use = "if you really need to exhaust the iterator, consider `.for_each(drop)` instead"]fn collect<B>(self) -> B where
B: FromIterator<Self::Item>,
1.0.0[src]Transforms an iterator into a collection. Read more
fn partition<B, F>(self, f: F) -> (B, B) where
B: Default + Extend<Self::Item>,
F: FnMut(&Self::Item) -> bool,
1.0.0[src]
fn partition<B, F>(self, f: F) -> (B, B) where
B: Default + Extend<Self::Item>,
F: FnMut(&Self::Item) -> bool,
1.0.0[src]Consumes an iterator, creating two collections from it. Read more
fn partition_in_place<'a, T, P>(self, predicate: P) -> usize where
Self: DoubleEndedIterator<Item = &'a mut T>,
T: 'a,
P: FnMut(&T) -> bool,
[src]
fn partition_in_place<'a, T, P>(self, predicate: P) -> usize where
Self: DoubleEndedIterator<Item = &'a mut T>,
T: 'a,
P: FnMut(&T) -> bool,
[src]🔬 This is a nightly-only experimental API. (iter_partition_in_place
)
new API
Reorders the elements of this iterator in-place according to the given predicate,
such that all those that return true
precede all those that return false
.
Returns the number of true
elements found. Read more
fn is_partitioned<P>(self, predicate: P) -> bool where
P: FnMut(Self::Item) -> bool,
[src]
fn is_partitioned<P>(self, predicate: P) -> bool where
P: FnMut(Self::Item) -> bool,
[src]🔬 This is a nightly-only experimental API. (iter_is_partitioned
)
new API
Checks if the elements of this iterator are partitioned according to the given predicate,
such that all those that return true
precede all those that return false
. Read more
fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R where
F: FnMut(B, Self::Item) -> R,
R: Try<Ok = B>,
1.27.0[src]
fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R where
F: FnMut(B, Self::Item) -> R,
R: Try<Ok = B>,
1.27.0[src]An iterator method that applies a function as long as it returns successfully, producing a single, final value. Read more
fn try_for_each<F, R>(&mut self, f: F) -> R where
F: FnMut(Self::Item) -> R,
R: Try<Ok = ()>,
1.27.0[src]
fn try_for_each<F, R>(&mut self, f: F) -> R where
F: FnMut(Self::Item) -> R,
R: Try<Ok = ()>,
1.27.0[src]An iterator method that applies a fallible function to each item in the iterator, stopping at the first error and returning that error. Read more
fn fold<B, F>(self, init: B, f: F) -> B where
F: FnMut(B, Self::Item) -> B,
1.0.0[src]
fn fold<B, F>(self, init: B, f: F) -> B where
F: FnMut(B, Self::Item) -> B,
1.0.0[src]Folds every element into an accumulator by applying an operation, returning the final result. Read more
fn reduce<F>(self, f: F) -> Option<Self::Item> where
F: FnMut(Self::Item, Self::Item) -> Self::Item,
1.51.0[src]
fn reduce<F>(self, f: F) -> Option<Self::Item> where
F: FnMut(Self::Item, Self::Item) -> Self::Item,
1.51.0[src]Reduces the elements to a single one, by repeatedly applying a reducing operation. Read more
fn all<F>(&mut self, f: F) -> bool where
F: FnMut(Self::Item) -> bool,
1.0.0[src]
fn all<F>(&mut self, f: F) -> bool where
F: FnMut(Self::Item) -> bool,
1.0.0[src]Tests if every element of the iterator matches a predicate. Read more
fn any<F>(&mut self, f: F) -> bool where
F: FnMut(Self::Item) -> bool,
1.0.0[src]
fn any<F>(&mut self, f: F) -> bool where
F: FnMut(Self::Item) -> bool,
1.0.0[src]Tests if any element of the iterator matches a predicate. Read more
fn find<P>(&mut self, predicate: P) -> Option<Self::Item> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]
fn find<P>(&mut self, predicate: P) -> Option<Self::Item> where
P: FnMut(&Self::Item) -> bool,
1.0.0[src]Searches for an element of an iterator that satisfies a predicate. Read more
fn find_map<B, F>(&mut self, f: F) -> Option<B> where
F: FnMut(Self::Item) -> Option<B>,
1.30.0[src]
fn find_map<B, F>(&mut self, f: F) -> Option<B> where
F: FnMut(Self::Item) -> Option<B>,
1.30.0[src]Applies function to the elements of iterator and returns the first non-none result. Read more
fn try_find<F, R>(
&mut self,
f: F
) -> Result<Option<Self::Item>, <R as Try>::Error> where
F: FnMut(&Self::Item) -> R,
R: Try<Ok = bool>,
[src]
fn try_find<F, R>(
&mut self,
f: F
) -> Result<Option<Self::Item>, <R as Try>::Error> where
F: FnMut(&Self::Item) -> R,
R: Try<Ok = bool>,
[src]🔬 This is a nightly-only experimental API. (try_find
)
new API
Applies function to the elements of iterator and returns the first true result or the first error. Read more
fn position<P>(&mut self, predicate: P) -> Option<usize> where
P: FnMut(Self::Item) -> bool,
1.0.0[src]
fn position<P>(&mut self, predicate: P) -> Option<usize> where
P: FnMut(Self::Item) -> bool,
1.0.0[src]Searches for an element in an iterator, returning its index. Read more
fn rposition<P>(&mut self, predicate: P) -> Option<usize> where
Self: ExactSizeIterator + DoubleEndedIterator,
P: FnMut(Self::Item) -> bool,
1.0.0[src]
fn rposition<P>(&mut self, predicate: P) -> Option<usize> where
Self: ExactSizeIterator + DoubleEndedIterator,
P: FnMut(Self::Item) -> bool,
1.0.0[src]Searches for an element in an iterator from the right, returning its index. Read more
fn max(self) -> Option<Self::Item> where
Self::Item: Ord,
1.0.0[src]
fn max(self) -> Option<Self::Item> where
Self::Item: Ord,
1.0.0[src]Returns the maximum element of an iterator. Read more
fn min(self) -> Option<Self::Item> where
Self::Item: Ord,
1.0.0[src]
fn min(self) -> Option<Self::Item> where
Self::Item: Ord,
1.0.0[src]Returns the minimum element of an iterator. Read more
fn max_by_key<B, F>(self, f: F) -> Option<Self::Item> where
B: Ord,
F: FnMut(&Self::Item) -> B,
1.6.0[src]
fn max_by_key<B, F>(self, f: F) -> Option<Self::Item> where
B: Ord,
F: FnMut(&Self::Item) -> B,
1.6.0[src]Returns the element that gives the maximum value from the specified function. Read more
fn max_by<F>(self, compare: F) -> Option<Self::Item> where
F: FnMut(&Self::Item, &Self::Item) -> Ordering,
1.15.0[src]
fn max_by<F>(self, compare: F) -> Option<Self::Item> where
F: FnMut(&Self::Item, &Self::Item) -> Ordering,
1.15.0[src]Returns the element that gives the maximum value with respect to the specified comparison function. Read more
fn min_by_key<B, F>(self, f: F) -> Option<Self::Item> where
B: Ord,
F: FnMut(&Self::Item) -> B,
1.6.0[src]
fn min_by_key<B, F>(self, f: F) -> Option<Self::Item> where
B: Ord,
F: FnMut(&Self::Item) -> B,
1.6.0[src]Returns the element that gives the minimum value from the specified function. Read more
fn min_by<F>(self, compare: F) -> Option<Self::Item> where
F: FnMut(&Self::Item, &Self::Item) -> Ordering,
1.15.0[src]
fn min_by<F>(self, compare: F) -> Option<Self::Item> where
F: FnMut(&Self::Item, &Self::Item) -> Ordering,
1.15.0[src]Returns the element that gives the minimum value with respect to the specified comparison function. Read more
fn rev(self) -> Rev<Self> where
Self: DoubleEndedIterator,
1.0.0[src]
fn rev(self) -> Rev<Self> where
Self: DoubleEndedIterator,
1.0.0[src]Reverses an iterator’s direction. Read more
fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB) where
Self: Iterator<Item = (A, B)>,
FromA: Default + Extend<A>,
FromB: Default + Extend<B>,
1.0.0[src]
fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB) where
Self: Iterator<Item = (A, B)>,
FromA: Default + Extend<A>,
FromB: Default + Extend<B>,
1.0.0[src]Converts an iterator of pairs into a pair of containers. Read more
fn copied<'a, T>(self) -> Copied<Self> where
Self: Iterator<Item = &'a T>,
T: 'a + Copy,
1.36.0[src]
fn copied<'a, T>(self) -> Copied<Self> where
Self: Iterator<Item = &'a T>,
T: 'a + Copy,
1.36.0[src]Creates an iterator which copies all of its elements. Read more
fn cloned<'a, T>(self) -> Cloned<Self> where
Self: Iterator<Item = &'a T>,
T: 'a + Clone,
1.0.0[src]
fn cloned<'a, T>(self) -> Cloned<Self> where
Self: Iterator<Item = &'a T>,
T: 'a + Clone,
1.0.0[src]fn sum<S>(self) -> S where
S: Sum<Self::Item>,
1.11.0[src]
fn sum<S>(self) -> S where
S: Sum<Self::Item>,
1.11.0[src]Sums the elements of an iterator. Read more
fn product<P>(self) -> P where
P: Product<Self::Item>,
1.11.0[src]
fn product<P>(self) -> P where
P: Product<Self::Item>,
1.11.0[src]Iterates over the entire iterator, multiplying all the elements Read more
fn cmp<I>(self, other: I) -> Ordering where
I: IntoIterator<Item = Self::Item>,
Self::Item: Ord,
1.5.0[src]
fn cmp<I>(self, other: I) -> Ordering where
I: IntoIterator<Item = Self::Item>,
Self::Item: Ord,
1.5.0[src]Lexicographically compares the elements of this Iterator
with those
of another. Read more
fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Ordering,
[src]
fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Ordering,
[src]iter_order_by
)Lexicographically compares the elements of this Iterator
with those
of another with respect to the specified comparison function. Read more
fn partial_cmp<I>(self, other: I) -> Option<Ordering> where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]
fn partial_cmp<I>(self, other: I) -> Option<Ordering> where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]Lexicographically compares the elements of this Iterator
with those
of another. Read more
fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering> where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
[src]
fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering> where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
[src]iter_order_by
)Lexicographically compares the elements of this Iterator
with those
of another with respect to the specified comparison function. Read more
fn eq<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialEq<<I as IntoIterator>::Item>,
1.5.0[src]
fn eq<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialEq<<I as IntoIterator>::Item>,
1.5.0[src]fn eq_by<I, F>(self, other: I, eq: F) -> bool where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> bool,
[src]
fn eq_by<I, F>(self, other: I, eq: F) -> bool where
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> bool,
[src]iter_order_by
)fn ne<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialEq<<I as IntoIterator>::Item>,
1.5.0[src]
fn ne<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialEq<<I as IntoIterator>::Item>,
1.5.0[src]fn lt<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]
fn lt<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]Determines if the elements of this Iterator
are lexicographically
less than those of another. Read more
fn le<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]
fn le<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]Determines if the elements of this Iterator
are lexicographically
less or equal to those of another. Read more
fn gt<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]
fn gt<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]Determines if the elements of this Iterator
are lexicographically
greater than those of another. Read more
fn ge<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]
fn ge<I>(self, other: I) -> bool where
I: IntoIterator,
Self::Item: PartialOrd<<I as IntoIterator>::Item>,
1.5.0[src]Determines if the elements of this Iterator
are lexicographically
greater than or equal to those of another. Read more
fn is_sorted(self) -> bool where
Self::Item: PartialOrd<Self::Item>,
[src]
fn is_sorted(self) -> bool where
Self::Item: PartialOrd<Self::Item>,
[src]🔬 This is a nightly-only experimental API. (is_sorted
)
new API
Checks if the elements of this iterator are sorted. Read more
fn is_sorted_by<F>(self, compare: F) -> bool where
F: FnMut(&Self::Item, &Self::Item) -> Option<Ordering>,
[src]
fn is_sorted_by<F>(self, compare: F) -> bool where
F: FnMut(&Self::Item, &Self::Item) -> Option<Ordering>,
[src]🔬 This is a nightly-only experimental API. (is_sorted
)
new API
Checks if the elements of this iterator are sorted using the given comparator function. Read more
fn is_sorted_by_key<F, K>(self, f: F) -> bool where
F: FnMut(Self::Item) -> K,
K: PartialOrd<K>,
[src]
fn is_sorted_by_key<F, K>(self, f: F) -> bool where
F: FnMut(Self::Item) -> K,
K: PartialOrd<K>,
[src]🔬 This is a nightly-only experimental API. (is_sorted
)
new API
Checks if the elements of this iterator are sorted using the given key extraction function. Read more
impl<'a, T: ?Sized + Ord, const NUM: usize, const DEN: usize> Ord for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized + Ord, const NUM: usize, const DEN: usize> Ord for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized, const NUM: usize, const DEN: usize, const N: usize, const D: usize> PartialEq<StaticRcRef<'a, T, N, D>> for StaticRcRef<'a, T, NUM, DEN> where
T: PartialEq<T>,
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize, const N: usize, const D: usize> PartialEq<StaticRcRef<'a, T, N, D>> for StaticRcRef<'a, T, NUM, DEN> where
T: PartialEq<T>,
[src]fn eq(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn eq(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests for self
and other
values to be equal, and is used
by ==
. Read more
fn ne(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn ne(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests for !=
.
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize, const N: usize, const D: usize> PartialOrd<StaticRcRef<'a, T, N, D>> for StaticRcRef<'a, T, NUM, DEN> where
T: PartialOrd<T>,
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize, const N: usize, const D: usize> PartialOrd<StaticRcRef<'a, T, N, D>> for StaticRcRef<'a, T, NUM, DEN> where
T: PartialOrd<T>,
[src]fn partial_cmp(&self, other: &StaticRcRef<'a, T, N, D>) -> Option<Ordering>
[src]
fn partial_cmp(&self, other: &StaticRcRef<'a, T, N, D>) -> Option<Ordering>
[src]This method returns an ordering between self
and other
values if one exists. Read more
fn lt(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn lt(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests less than (for self
and other
) and is used by the <
operator. Read more
fn le(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn le(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
fn gt(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn gt(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests greater than (for self
and other
) and is used by the >
operator. Read more
fn ge(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]
fn ge(&self, other: &StaticRcRef<'a, T, N, D>) -> bool
[src]This method tests greater than or equal to (for self
and other
) and is used by the >=
operator. Read more
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Pointer for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Pointer for StaticRcRef<'a, T, NUM, DEN>
[src]impl<'a, T: ?Sized + Eq, const NUM: usize, const DEN: usize> Eq for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, I: FusedIterator + ?Sized, const N: usize> FusedIterator for StaticRcRef<'a, I, N, N>
[src]
impl<'a, T: ?Sized + Send, const NUM: usize, const DEN: usize> Send for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized + Sync, const NUM: usize, const DEN: usize> Sync for StaticRcRef<'a, T, NUM, DEN>
[src]
impl<'a, T: ?Sized, const NUM: usize, const DEN: usize> Unpin for StaticRcRef<'a, T, NUM, DEN>
[src]
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<F> IntoFuture for F where
F: Future,
[src]
impl<F> IntoFuture for F where
F: Future,
[src]type Output = <F as Future>::Output
type Output = <F as Future>::Output
into_future
)The output that the future will produce on completion.
type Future = F
type Future = F
into_future
)Which kind of future are we turning this into?
pub fn into_future(self) -> <F as IntoFuture>::Future
[src]
pub fn into_future(self) -> <F as IntoFuture>::Future
[src]into_future
)Creates a future from a value.
impl<I> IntoIterator for I where
I: Iterator,
[src]
impl<I> IntoIterator for I where
I: Iterator,
[src]