pub struct StringTemplate(/* private fields */);Implementations§
Source§impl StringTemplate
 
impl StringTemplate
pub fn Expression(&self) -> impl Iterator<Item = Expression>
Sourcepub fn new(node: SyntaxNode) -> Option<Self>
 
pub fn new(node: SyntaxNode) -> Option<Self>
Create a new node from a SyntaxNode, if the SyntaxNode is of the correct kind
Methods from Deref<Target = SyntaxNode>§
pub fn child_node(&self, kind: SyntaxKind) -> Option<SyntaxNode>
pub fn child_token(&self, kind: SyntaxKind) -> Option<SyntaxToken>
pub fn child_text(&self, kind: SyntaxKind) -> Option<SmolStr>
pub fn descendants(&self) -> impl Iterator<Item = SyntaxNode>
pub fn kind(&self) -> SyntaxKind
pub fn children(&self) -> impl Iterator<Item = SyntaxNode>
pub fn children_with_tokens(&self) -> impl Iterator<Item = NodeOrToken>
pub fn text(&self) -> SyntaxText
pub fn parent(&self) -> Option<SyntaxNode>
pub fn first_token(&self) -> Option<SyntaxToken>
pub fn last_token(&self) -> Option<SyntaxToken>
pub fn token_at_offset(&self, offset: TextSize) -> TokenAtOffset<SyntaxToken>
pub fn first_child(&self) -> Option<SyntaxNode>
pub fn first_child_or_token(&self) -> Option<NodeOrToken>
pub fn next_sibling(&self) -> Option<SyntaxNode>
Methods from Deref<Target = SyntaxNode<Language>>§
Sourcepub fn replace_with(&self, replacement: GreenNode) -> GreenNode
 
pub fn replace_with(&self, replacement: GreenNode) -> GreenNode
Returns a green tree, equal to the green tree this node belongs to, except with this node substituted. The complexity of the operation is proportional to the depth of the tree.
pub fn kind(&self) -> <L as Language>::Kind
pub fn text_range(&self) -> TextRange
pub fn index(&self) -> usize
pub fn text(&self) -> SyntaxText
pub fn green(&self) -> Cow<'_, GreenNodeData>
pub fn parent(&self) -> Option<SyntaxNode<L>>
pub fn ancestors(&self) -> impl Iterator<Item = SyntaxNode<L>>
pub fn children(&self) -> SyntaxNodeChildren<L>
pub fn children_with_tokens(&self) -> SyntaxElementChildren<L>
pub fn first_child(&self) -> Option<SyntaxNode<L>>
pub fn first_child_by_kind( &self, matcher: &impl Fn(<L as Language>::Kind) -> bool, ) -> Option<SyntaxNode<L>>
pub fn last_child(&self) -> Option<SyntaxNode<L>>
pub fn first_child_or_token( &self, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn first_child_or_token_by_kind( &self, matcher: &impl Fn(<L as Language>::Kind) -> bool, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn last_child_or_token( &self, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn next_sibling(&self) -> Option<SyntaxNode<L>>
pub fn next_sibling_by_kind( &self, matcher: &impl Fn(<L as Language>::Kind) -> bool, ) -> Option<SyntaxNode<L>>
pub fn prev_sibling(&self) -> Option<SyntaxNode<L>>
pub fn next_sibling_or_token( &self, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn next_sibling_or_token_by_kind( &self, matcher: &impl Fn(<L as Language>::Kind) -> bool, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn prev_sibling_or_token( &self, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
Sourcepub fn first_token(&self) -> Option<SyntaxToken<L>>
 
pub fn first_token(&self) -> Option<SyntaxToken<L>>
Return the leftmost token in the subtree of this node.
Sourcepub fn last_token(&self) -> Option<SyntaxToken<L>>
 
pub fn last_token(&self) -> Option<SyntaxToken<L>>
Return the rightmost token in the subtree of this node.
pub fn siblings( &self, direction: Direction, ) -> impl Iterator<Item = SyntaxNode<L>>
pub fn siblings_with_tokens( &self, direction: Direction, ) -> impl Iterator<Item = NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
pub fn descendants(&self) -> impl Iterator<Item = SyntaxNode<L>>
pub fn descendants_with_tokens( &self, ) -> impl Iterator<Item = NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
Sourcepub fn preorder(&self) -> Preorder<L>
 
pub fn preorder(&self) -> Preorder<L>
Traverse the subtree rooted at the current node (including the current node) in preorder, excluding tokens.
Sourcepub fn preorder_with_tokens(&self) -> PreorderWithTokens<L>
 
pub fn preorder_with_tokens(&self) -> PreorderWithTokens<L>
Traverse the subtree rooted at the current node (including the current node) in preorder, including tokens.
Sourcepub fn token_at_offset(&self, offset: TextSize) -> TokenAtOffset<SyntaxToken<L>>
 
pub fn token_at_offset(&self, offset: TextSize) -> TokenAtOffset<SyntaxToken<L>>
Find a token in the subtree corresponding to this node, which covers the offset. Precondition: offset must be within node’s range.
Sourcepub fn covering_element(
    &self,
    range: TextRange,
) -> NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>
 
pub fn covering_element( &self, range: TextRange, ) -> NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>
Return the deepest node or token in the current subtree that fully contains the range. If the range is empty and is contained in two leaf nodes, either one can be returned. Precondition: range must be contained within the current node
Sourcepub fn child_or_token_at_range(
    &self,
    range: TextRange,
) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
 
pub fn child_or_token_at_range( &self, range: TextRange, ) -> Option<NodeOrToken<SyntaxNode<L>, SyntaxToken<L>>>
Finds a SyntaxElement which intersects with a given range. If
there are several intersecting elements, any one can be returned.
The method uses binary search internally, so it’s complexity is
O(log(N)) where N = self.children_with_tokens().count().
Sourcepub fn clone_subtree(&self) -> SyntaxNode<L>
 
pub fn clone_subtree(&self) -> SyntaxNode<L>
Returns an independent copy of the subtree rooted at this node.
The parent of the returned node will be None, the start offset will be
zero, but, otherwise, it’ll be equivalent to the source node.
pub fn clone_for_update(&self) -> SyntaxNode<L>
pub fn is_mutable(&self) -> bool
pub fn detach(&self)
pub fn splice_children<I>(&self, to_delete: Range<usize>, to_insert: I)
Trait Implementations§
Source§impl Clone for StringTemplate
 
impl Clone for StringTemplate
Source§fn clone(&self) -> StringTemplate
 
fn clone(&self) -> StringTemplate
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for StringTemplate
 
impl Debug for StringTemplate
Source§impl Deref for StringTemplate
 
impl Deref for StringTemplate
Source§impl From<StringTemplate> for SyntaxNode
 
impl From<StringTemplate> for SyntaxNode
Source§fn from(value: StringTemplate) -> Self
 
fn from(value: StringTemplate) -> Self
Source§impl From<SyntaxNode> for StringTemplate
 
impl From<SyntaxNode> for StringTemplate
Source§fn from(node: SyntaxNode) -> Self
 
fn from(node: SyntaxNode) -> Self
Source§impl Spanned for StringTemplate
 
impl Spanned for StringTemplate
fn span(&self) -> Span
fn source_file(&self) -> Option<&SourceFile>
fn to_source_location(&self) -> SourceLocation
Auto Trait Implementations§
impl Freeze for StringTemplate
impl !RefUnwindSafe for StringTemplate
impl !Send for StringTemplate
impl !Sync for StringTemplate
impl Unpin for StringTemplate
impl !UnwindSafe for StringTemplate
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more