diff options
Diffstat (limited to 'crates/ra_syntax')
-rw-r--r-- | crates/ra_syntax/src/algo.rs | 17 | ||||
-rw-r--r-- | crates/ra_syntax/src/lib.rs | 6 | ||||
-rw-r--r-- | crates/ra_syntax/src/syntax_node.rs | 1 |
3 files changed, 7 insertions, 17 deletions
diff --git a/crates/ra_syntax/src/algo.rs b/crates/ra_syntax/src/algo.rs index ecd42c133..45f624810 100644 --- a/crates/ra_syntax/src/algo.rs +++ b/crates/ra_syntax/src/algo.rs | |||
@@ -5,16 +5,9 @@ use std::ops::RangeInclusive; | |||
5 | use itertools::Itertools; | 5 | use itertools::Itertools; |
6 | 6 | ||
7 | use crate::{ | 7 | use crate::{ |
8 | AstNode, Direction, NodeOrToken, SourceFile, SyntaxElement, SyntaxNode, SyntaxNodePtr, | 8 | AstNode, Direction, NodeOrToken, SyntaxElement, SyntaxNode, SyntaxNodePtr, TextRange, TextUnit, |
9 | SyntaxToken, TextRange, TextUnit, | ||
10 | }; | 9 | }; |
11 | 10 | ||
12 | pub use rowan::TokenAtOffset; | ||
13 | |||
14 | pub fn find_token_at_offset(node: &SyntaxNode, offset: TextUnit) -> TokenAtOffset<SyntaxToken> { | ||
15 | node.token_at_offset(offset) | ||
16 | } | ||
17 | |||
18 | /// Returns ancestors of the node at the offset, sorted by length. This should | 11 | /// Returns ancestors of the node at the offset, sorted by length. This should |
19 | /// do the right thing at an edge, e.g. when searching for expressions at `{ | 12 | /// do the right thing at an edge, e.g. when searching for expressions at `{ |
20 | /// <|>foo }` we will get the name reference instead of the whole block, which | 13 | /// <|>foo }` we will get the name reference instead of the whole block, which |
@@ -24,7 +17,7 @@ pub fn ancestors_at_offset( | |||
24 | node: &SyntaxNode, | 17 | node: &SyntaxNode, |
25 | offset: TextUnit, | 18 | offset: TextUnit, |
26 | ) -> impl Iterator<Item = SyntaxNode> { | 19 | ) -> impl Iterator<Item = SyntaxNode> { |
27 | find_token_at_offset(node, offset) | 20 | node.token_at_offset(offset) |
28 | .map(|token| token.parent().ancestors()) | 21 | .map(|token| token.parent().ancestors()) |
29 | .kmerge_by(|node1, node2| node1.text_range().len() < node2.text_range().len()) | 22 | .kmerge_by(|node1, node2| node1.text_range().len() < node2.text_range().len()) |
30 | } | 23 | } |
@@ -137,14 +130,14 @@ fn with_children( | |||
137 | let len = new_children.iter().map(|it| it.text_len()).sum::<TextUnit>(); | 130 | let len = new_children.iter().map(|it| it.text_len()).sum::<TextUnit>(); |
138 | let new_node = | 131 | let new_node = |
139 | rowan::GreenNode::new(rowan::cursor::SyntaxKind(parent.kind() as u16), new_children); | 132 | rowan::GreenNode::new(rowan::cursor::SyntaxKind(parent.kind() as u16), new_children); |
140 | let new_file_node = parent.replace_with(new_node); | 133 | let new_root_node = parent.replace_with(new_node); |
141 | let file = SourceFile::new(new_file_node); | 134 | let new_root_node = SyntaxNode::new_root(new_root_node); |
142 | 135 | ||
143 | // FIXME: use a more elegant way to re-fetch the node (#1185), make | 136 | // FIXME: use a more elegant way to re-fetch the node (#1185), make |
144 | // `range` private afterwards | 137 | // `range` private afterwards |
145 | let mut ptr = SyntaxNodePtr::new(parent); | 138 | let mut ptr = SyntaxNodePtr::new(parent); |
146 | ptr.range = TextRange::offset_len(ptr.range().start(), len); | 139 | ptr.range = TextRange::offset_len(ptr.range().start(), len); |
147 | ptr.to_node(file.syntax()).to_owned() | 140 | ptr.to_node(&new_root_node) |
148 | } | 141 | } |
149 | 142 | ||
150 | fn position_of_child(parent: &SyntaxNode, child: SyntaxElement) -> usize { | 143 | fn position_of_child(parent: &SyntaxNode, child: SyntaxElement) -> usize { |
diff --git a/crates/ra_syntax/src/lib.rs b/crates/ra_syntax/src/lib.rs index 7b778f38c..d02078256 100644 --- a/crates/ra_syntax/src/lib.rs +++ b/crates/ra_syntax/src/lib.rs | |||
@@ -44,12 +44,10 @@ pub use crate::{ | |||
44 | syntax_error::{Location, SyntaxError, SyntaxErrorKind}, | 44 | syntax_error::{Location, SyntaxError, SyntaxErrorKind}, |
45 | syntax_node::{ | 45 | syntax_node::{ |
46 | Direction, NodeOrToken, SyntaxElement, SyntaxNode, SyntaxToken, SyntaxTreeBuilder, | 46 | Direction, NodeOrToken, SyntaxElement, SyntaxNode, SyntaxToken, SyntaxTreeBuilder, |
47 | WalkEvent, | ||
48 | }, | 47 | }, |
49 | }; | 48 | }; |
50 | pub use ra_parser::SyntaxKind; | 49 | pub use ra_parser::{SyntaxKind, T}; |
51 | pub use ra_parser::T; | 50 | pub use rowan::{SmolStr, SyntaxText, TextRange, TextUnit, TokenAtOffset, WalkEvent}; |
52 | pub use rowan::{SmolStr, SyntaxText, TextRange, TextUnit}; | ||
53 | 51 | ||
54 | /// `Parse` is the result of the parsing: a syntax tree and a collection of | 52 | /// `Parse` is the result of the parsing: a syntax tree and a collection of |
55 | /// errors. | 53 | /// errors. |
diff --git a/crates/ra_syntax/src/syntax_node.rs b/crates/ra_syntax/src/syntax_node.rs index 95795a27a..b2f5b8c64 100644 --- a/crates/ra_syntax/src/syntax_node.rs +++ b/crates/ra_syntax/src/syntax_node.rs | |||
@@ -14,7 +14,6 @@ use crate::{ | |||
14 | Parse, SmolStr, SyntaxKind, TextUnit, | 14 | Parse, SmolStr, SyntaxKind, TextUnit, |
15 | }; | 15 | }; |
16 | 16 | ||
17 | pub use rowan::WalkEvent; | ||
18 | pub(crate) use rowan::{GreenNode, GreenToken}; | 17 | pub(crate) use rowan::{GreenNode, GreenToken}; |
19 | 18 | ||
20 | #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] | 19 | #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] |