Struct syn::buffer::Cursor [−][src]
pub struct Cursor<'a> { /* fields omitted */ }
Expand description
A cheaply copyable cursor into a TokenBuffer
.
This cursor holds a shared reference into the immutable data which is used
internally to represent a TokenStream
, and can be efficiently manipulated
and copied around.
An empty Cursor
can be created directly, or one may create a TokenBuffer
object and get a cursor to its first token with begin()
.
Two cursors are equal if they have the same location in the same input stream, and have the same scope.
This type is available only if Syn is built with the "parsing"
feature.
Implementations
Checks whether the cursor is currently pointing at the end of its valid scope.
If the cursor is pointing at a Group
with the given delimiter, returns
a cursor into that group and one pointing to the next TokenTree
.
If the cursor is pointing at a Ident
, returns it along with a cursor
pointing at the next TokenTree
.
If the cursor is pointing at a Punct
, returns it along with a cursor
pointing at the next TokenTree
.
If the cursor is pointing at a Literal
, return it along with a cursor
pointing at the next TokenTree
.
If the cursor is pointing at a Lifetime
, returns it along with a
cursor pointing at the next TokenTree
.
Copies all remaining tokens visible from this cursor into a
TokenStream
.
If the cursor is pointing at a TokenTree
, returns it along with a
cursor pointing at the next TokenTree
.
Returns None
if the cursor has reached the end of its stream.
This method does not treat None
-delimited groups as transparent, and
will return a Group(None, ..)
if the cursor is looking at one.
Trait Implementations
Auto Trait Implementations
impl<'a> RefUnwindSafe for Cursor<'a>
impl<'a> UnwindSafe for Cursor<'a>
Blanket Implementations
Mutably borrows from an owned value. Read more