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
- previous_non_ trivia_ token 
- skip_trivia_ token 
- Skip to next non triviatoken
- skip_whitespace_ token 
- Skip to next non whitespacetoken