Expand description
Collection of assorted algorithms for syntax trees.
Functions§
- ancestors_
at_ offset - Returns ancestors of the node at the offset, sorted by length. This should
do the right thing at an edge, e.g. when searching for expressions at
{ $0foo }
we will get the name reference instead of the whole block, which we would get if we just didfind_token_at_offset(...).flat_map(|t| t.parent().ancestors())
. - find_
node_ at_ offset - Finds a node of specific Ast type at offset. Note that this is slightly imprecise: if the cursor is strictly between two nodes of the desired type, as in
- find_
node_ at_ range - has_
errors - least_
common_ ancestor - least_
common_ ancestor_ element - neighbor
- non_
trivia_ sibling - Finds the first sibling in the given direction which is not
trivia
- skip_
trivia_ token - Skip to next non
trivia
token - skip_
whitespace_ token - Skip to next non
whitespace
token