[−][src]Struct full_moon::ast::punctuated::Punctuated
A punctuated sequence of node T
separated by
TokenReference
.
Refer to the module documentation for more details.
Implementations
impl<'a, T> Punctuated<'a, T>
[src]
pub fn new() -> Self
[src]
Creates an empty punctuated sequence
let mut punctuated: Punctuated<i32> = Punctuated::new();
pub fn is_empty(&self) -> bool
[src]
Returns whether there's any nodes in the punctuated sequence
let mut punctuated = Punctuated::new(); assert!(punctuated.is_empty()); punctuated.push(Pair::new((), None)); assert!(!punctuated.is_empty());
pub fn len(&self) -> usize
[src]
Returns the number of pairs in the punctuated sequence
let mut punctuated = Punctuated::new(); assert_eq!(punctuated.len(), 0); punctuated.push(Pair::new((), None)); assert_eq!(punctuated.len(), 1);
pub fn iter(&self) -> Iter<'a, '_, T>ⓘ
[src]
Returns an iterator over references of the sequence values, ignoring punctuation
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); let mut iterator = punctuated.iter(); assert_eq!(iterator.next(), Some(&1)); assert_eq!(iterator.next(), None);
pub fn iter_mut(&mut self) -> IterMut<'a, '_, T>ⓘ
[src]
Returns an iterator over mutable references of the sequence values, ignoring punctuation
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); for item in punctuated.iter_mut() { *item += 1; } assert_eq!(punctuated.pop(), Some(Pair::new(2, None)));
pub fn into_pairs(self) -> impl Iterator<Item = Pair<'a, T>>
[src]
Returns an iterator over the Pair
sequences
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); let mut iterator = punctuated.into_pairs(); assert_eq!(iterator.next(), Some(Pair::new(1, None))); assert_eq!(iterator.next(), None);
pub fn last(&self) -> Option<&Pair<'a, T>>
[src]
Returns the last Pair
in the sequence
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); assert_eq!(punctuated.last(), Some(&Pair::new(1, None)));
pub fn pairs(&self) -> impl Iterator<Item = &Pair<'a, T>>
[src]
Returns an iterator over the Pair
sequences as references
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); let mut iterator = punctuated.pairs(); assert_eq!(iterator.next(), Some(&Pair::new(1, None))); assert_eq!(iterator.next(), None);
pub fn pairs_mut(&mut self) -> impl Iterator<Item = &mut Pair<'a, T>>
[src]
Returns an iterator over the Pair
sequences as mutable references
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); for item in punctuated.pairs_mut() { *item.value_mut() += 1; } assert_eq!(punctuated.pop(), Some(Pair::new(2, None)));
pub fn pop(&mut self) -> Option<Pair<'a, T>>
[src]
Pops off the last Pair
, if it isn't empty
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); assert_eq!(punctuated.pop(), Some(Pair::new(1, None)));
pub fn push(&mut self, pair: Pair<'a, T>)
[src]
Pushes a new Pair
onto the sequence
let mut punctuated = Punctuated::new(); punctuated.push(Pair::new(1, None)); assert_eq!(punctuated.pop(), Some(Pair::new(1, None)));
Trait Implementations
impl<'a, T: Clone> Clone for Punctuated<'a, T>
[src]
fn clone(&self) -> Punctuated<'a, T>
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<'a, T: Debug> Debug for Punctuated<'a, T>
[src]
impl<'a, T: Default> Default for Punctuated<'a, T>
[src]
fn default() -> Punctuated<'a, T>
[src]
impl<'de: 'a, 'a, T> Deserialize<'de> for Punctuated<'a, T> where
T: Deserialize<'de>,
[src]
T: Deserialize<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
[src]
__D: Deserializer<'de>,
impl<'a, T> Display for Punctuated<'a, T> where
T: Display,
[src]
T: Display,
impl<'a, T> Extend<Pair<'a, T>> for Punctuated<'a, T>
[src]
fn extend<I: IntoIterator<Item = Pair<'a, T>>>(&mut self, iter: I)
[src]
fn extend_one(&mut self, item: A)
[src]
fn extend_reserve(&mut self, additional: usize)
[src]
impl<'a, T> FromIterator<Pair<'a, T>> for Punctuated<'a, T>
[src]
fn from_iter<I: IntoIterator<Item = Pair<'a, T>>>(iter: I) -> Self
[src]
impl<'a, T> IntoIterator for Punctuated<'a, T>
[src]
type Item = T
The type of the elements being iterated over.
type IntoIter = IntoIter<'a, T>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Self::IntoIter
[src]
impl<'a: 'b, 'b, T> IntoIterator for &'b Punctuated<'a, T>
[src]
type Item = &'b T
The type of the elements being iterated over.
type IntoIter = Iter<'a, 'b, T>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Self::IntoIter
[src]
impl<'a: 'b, 'b, T> IntoIterator for &'b mut Punctuated<'a, T>
[src]
type Item = &'b mut T
The type of the elements being iterated over.
type IntoIter = IterMut<'a, 'b, T>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Self::IntoIter
[src]
impl<'a, T: Node<'a>> Node<'a> for Punctuated<'a, T>
[src]
fn start_position(&self) -> Option<Position>
[src]
fn end_position(&self) -> Option<Position>
[src]
fn similar(&self, other: &Self) -> bool
[src]
fn tokens<'b>(&'b self) -> Tokens<'a, 'b>ⓘ
[src]
fn range(&self) -> Option<(Position, Position)>
[src]
fn surrounding_trivia<'b>(
&'b self
) -> (Vec<Cow<'b, Token<'ast>>>, Vec<Cow<'b, Token<'ast>>>)
[src]
&'b self
) -> (Vec<Cow<'b, Token<'ast>>>, Vec<Cow<'b, Token<'ast>>>)
impl<T, '_> Owned for Punctuated<'_, T> where
T: Owned,
[src]
T: Owned,
type Owned = Punctuated<'static, <T as Owned>::Owned>
What an owned version of the object looks like. Usually contains a 'static
lifetime.
fn owned(&self) -> Self::Owned
[src]
impl<'a, T: PartialEq> PartialEq<Punctuated<'a, T>> for Punctuated<'a, T>
[src]
fn eq(&self, other: &Punctuated<'a, T>) -> bool
[src]
fn ne(&self, other: &Punctuated<'a, T>) -> bool
[src]
impl<'a, T> Serialize for Punctuated<'a, T> where
T: Serialize,
[src]
T: Serialize,
fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
__S: Serializer,
[src]
__S: Serializer,
impl<'a, T> StructuralPartialEq for Punctuated<'a, T>
[src]
Auto Trait Implementations
impl<'a, T> RefUnwindSafe for Punctuated<'a, T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<'a, T> Send for Punctuated<'a, T> where
T: Send,
T: Send,
impl<'a, T> Sync for Punctuated<'a, T> where
T: Sync,
T: Sync,
impl<'a, T> Unpin for Punctuated<'a, T> where
T: Unpin,
T: Unpin,
impl<'a, T> UnwindSafe for Punctuated<'a, T> where
T: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>,
[src]
T: for<'de> Deserialize<'de>,
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<I> IntoIterator for I where
I: Iterator,
[src]
I: Iterator,
type Item = <I as Iterator>::Item
The type of the elements being iterated over.
type IntoIter = I
Which kind of iterator are we turning this into?
pub fn into_iter(self) -> I
[src]
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,