Document perf characteristic of to_node
This commit is contained in:
parent
56e61bdfea
commit
e611c6758c
@ -32,6 +32,15 @@ pub fn new(node: &SyntaxNode) -> SyntaxNodePtr {
|
|||||||
SyntaxNodePtr { range: node.text_range(), kind: node.kind() }
|
SyntaxNodePtr { range: node.text_range(), kind: node.kind() }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// "Dereference" the pointer to get the node it points to.
|
||||||
|
///
|
||||||
|
/// Panics if node is not found, so make sure that `root` syntax tree is
|
||||||
|
/// equivalent (is build from the same text) to the tree which was
|
||||||
|
/// originally used to get this [`SyntaxNodePtr`].
|
||||||
|
///
|
||||||
|
/// The complexity is linear in the depth of the tree and logarithmic in
|
||||||
|
/// tree width. As most trees are shallow, thinking about this as
|
||||||
|
/// `O(log(N))` in the size of the tree is not too wrong!
|
||||||
pub fn to_node(&self, root: &SyntaxNode) -> SyntaxNode {
|
pub fn to_node(&self, root: &SyntaxNode) -> SyntaxNode {
|
||||||
assert!(root.parent().is_none());
|
assert!(root.parent().is_none());
|
||||||
successors(Some(root.clone()), |node| {
|
successors(Some(root.clone()), |node| {
|
||||||
|
Loading…
Reference in New Issue
Block a user