pub struct Cursor<'a> { /* private fields */ }
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.
See the module documentation for an example of a Cursor
in action.
This type is available if Syn is built with the "parsing"
feature.
Implementations§
Source§impl<'a> Cursor<'a>
impl<'a> Cursor<'a>
Sourcepub fn eof(self) -> bool
pub fn eof(self) -> bool
Checks whether the cursor is currently pointing at the end of its valid scope.
Sourcepub fn group(self, delim: Delimiter) -> Option<(Cursor<'a>, Span, Cursor<'a>)>
pub fn group(self, delim: Delimiter) -> Option<(Cursor<'a>, Span, Cursor<'a>)>
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
.
Sourcepub fn term(self) -> Option<(Span, Term, Cursor<'a>)>
pub fn term(self) -> Option<(Span, Term, Cursor<'a>)>
If the cursor is pointing at a Term
, returns it along with a cursor
pointing at the next TokenTree
.
Sourcepub fn op(self) -> Option<(Span, char, Spacing, Cursor<'a>)>
pub fn op(self) -> Option<(Span, char, Spacing, Cursor<'a>)>
If the cursor is pointing at an Op
, returns it along with a cursor
pointing at the next TokenTree
.
Sourcepub fn literal(self) -> Option<(Span, Literal, Cursor<'a>)>
pub fn literal(self) -> Option<(Span, Literal, Cursor<'a>)>
If the cursor is pointing at a Literal
, return it along with a cursor
pointing at the next TokenTree
.
Sourcepub fn token_stream(self) -> TokenStream
pub fn token_stream(self) -> TokenStream
Copies all remaining tokens visible from this cursor into a
TokenStream
.
Sourcepub fn token_tree(self) -> Option<(TokenTree, Cursor<'a>)>
pub fn token_tree(self) -> Option<(TokenTree, Cursor<'a>)>
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.