[][src]Struct syn::punctuated::Punctuated

pub struct Punctuated<T, P> { /* fields omitted */ }

A punctuated sequence of syntax tree nodes of type T separated by punctuation of type P.

Refer to the module documentation for details about punctuated sequences.

Methods

impl<T, P> Punctuated<T, P>
[src]

Creates an empty punctuated sequence.

Determines whether this punctuated sequence is empty, meaning it contains no syntax tree nodes or punctuation.

Returns the number of syntax tree nodes in this punctuated sequence.

This is the number of nodes of type T, not counting the punctuation of type P.

Borrows the first punctuated pair in this sequence.

Borrows the last punctuated pair in this sequence.

Mutably borrows the last punctuated pair in this sequence.

Important traits for Iter<'a, T>

Returns an iterator over borrowed syntax tree nodes of type &T.

Important traits for IterMut<'a, T>

Returns an iterator over mutably borrowed syntax tree nodes of type &mut T.

Important traits for Pairs<'a, T, P>

Returns an iterator over the contents of this sequence as borrowed punctuated pairs.

Important traits for PairsMut<'a, T, P>

Returns an iterator over the contents of this sequence as mutably borrowed punctuated pairs.

Important traits for IntoPairs<T, P>

Returns an iterator over the contents of this sequence as owned punctuated pairs.

Appends a syntax tree node onto the end of this punctuated sequence. The sequence must previously have a trailing punctuation.

Use push instead if the punctuated sequence may or may not already have trailing punctuation.

Panics

Panics if the sequence does not already have a trailing punctuation when this method is called.

Appends a trailing punctuation onto the end of this punctuated sequence. The sequence must be non-empty and must not already have trailing punctuation.

Panics

Panics if the sequence is empty or already has a trailing punctuation.

Removes the last punctuated pair from this sequence, or None if the sequence is empty.

Determines whether this punctuated sequence ends with a trailing punctuation.

Returns true if either this Punctuated is empty, or it has a trailing punctuation.

Equivalent to punctuated.is_empty() || punctuated.trailing_punct().

impl<T, P> Punctuated<T, P> where
    P: Default
[src]

Appends a syntax tree node onto the end of this punctuated sequence.

If there is not a trailing punctuation in this sequence when this method is called, the default value of punctuation type P is inserted before the given value of type T.

Inserts an element at position index.

Panics

Panics if index is greater than the number of elements previously in this punctuated sequence.

impl<T, P> Punctuated<T, P> where
    T: Synom,
    P: Synom
[src]

Parse zero or more syntax tree nodes with punctuation in between and no trailing punctuation.

Parse one or more syntax tree nodes with punctuation in bewteen and no trailing punctuation. allowing trailing punctuation.

Parse zero or more syntax tree nodes with punctuation in between and optional trailing punctuation.

Parse one or more syntax tree nodes with punctuation in between and optional trailing punctuation.

impl<T, P> Punctuated<T, P> where
    P: Synom
[src]

Parse zero or more syntax tree nodes using the given parser with punctuation in between and no trailing punctuation.

Parse one or more syntax tree nodes using the given parser with punctuation in between and no trailing punctuation.

Parse zero or more syntax tree nodes using the given parser with punctuation in between and optional trailing punctuation.

Parse one or more syntax tree nodes using the given parser with punctuation in between and optional trailing punctuation.

Trait Implementations

impl<T, P> ToTokens for Punctuated<T, P> where
    T: ToTokens,
    P: ToTokens
[src]

Write self to the given TokenStream. Read more

Convert self directly into a TokenStream object. Read more

impl<T: Eq, P: Eq> Eq for Punctuated<T, P>
[src]

impl<T: PartialEq, P: PartialEq> PartialEq for Punctuated<T, P>
[src]

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

impl<T: Hash, P: Hash> Hash for Punctuated<T, P>
[src]

Feeds this value into the given [Hasher]. Read more

Feeds a slice of this type into the given [Hasher]. Read more

impl<T: Clone, P: Clone> Clone for Punctuated<T, P>
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl<T: Debug, P: Debug> Debug for Punctuated<T, P>
[src]

Formats the value using the given formatter. Read more

impl<T, P> FromIterator<T> for Punctuated<T, P> where
    P: Default
[src]

Creates a value from an iterator. Read more

impl<T, P> Extend<T> for Punctuated<T, P> where
    P: Default
[src]

Extends a collection with the contents of an iterator. Read more

impl<T, P> FromIterator<Pair<T, P>> for Punctuated<T, P>
[src]

Creates a value from an iterator. Read more

impl<T, P> Extend<Pair<T, P>> for Punctuated<T, P>
[src]

Extends a collection with the contents of an iterator. Read more

impl<T, P> IntoIterator for Punctuated<T, P>
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl<'a, T, P> IntoIterator for &'a Punctuated<T, P>
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl<'a, T, P> IntoIterator for &'a mut Punctuated<T, P>
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl<T, P> Default for Punctuated<T, P>
[src]

Returns the "default value" for a type. Read more

impl<T, P> Index<usize> for Punctuated<T, P>
[src]

The returned type after indexing.

Performs the indexing (container[index]) operation.

impl<T, P> IndexMut<usize> for Punctuated<T, P>
[src]

Performs the mutable indexing (container[index]) operation.

Auto Trait Implementations

impl<T, P> Send for Punctuated<T, P> where
    P: Send,
    T: Send

impl<T, P> Sync for Punctuated<T, P> where
    P: Sync,
    T: Sync

Blanket Implementations

impl<T> Spanned for T where
    T: ToTokens
[src]

Returns a Span covering the complete contents of this syntax tree node, or [Span::call_site()] if this node is empty. Read more

impl<T> From for T
[src]

Performs the conversion.

impl<I> IntoIterator for I where
    I: Iterator
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl<T, U> Into for T where
    U: From<T>, 
[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T, U> TryFrom for T where
    T: From<U>, 
[src]

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

🔬 This is a nightly-only experimental API. (try_from)

Performs the conversion.

impl<T> Borrow for T where
    T: ?Sized
[src]

Important traits for &'a mut W

Immutably borrows from an owned value. Read more

impl<T> BorrowMut for T where
    T: ?Sized
[src]

Important traits for &'a mut W

Mutably borrows from an owned value. Read more

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

🔬 This is a nightly-only experimental API. (try_from)

Performs the conversion.

impl<T> Any for T where
    T: 'static + ?Sized
[src]

🔬 This is a nightly-only experimental API. (get_type_id)

this method will likely be replaced by an associated static

Gets the TypeId of self. Read more

impl<E> SpecializationError for E
[src]

🔬 This is a nightly-only experimental API. (rustc_private)

this crate is being loaded from the sysroot, an unstable location; did you mean to load this crate from crates.io via Cargo.toml instead?

Create an error for a missing method specialization. Defaults to panicking with type, trait & method names. S is the encoder/decoder state type, T is the type being encoded/decoded, and the arguments are the names of the trait and method that should've been overridden. Read more

impl<T> Erased for T
[src]

impl<T> Send for T where
    T: ?Sized
[src]

impl<T> Sync for T where
    T: ?Sized
[src]

impl<T> Erased for T