Struct rowan::ast::SyntaxNodePtr

source ·
pub struct SyntaxNodePtr<L: Language> { /* private fields */ }
Expand description

A “pointer” to a SyntaxNode, via location in the source code.

§Note

Since the location is source code dependent, this must not be used with mutable syntax trees. Any changes made in such trees causes the pointed node’s source location to change, invalidating the pointer.

Implementations§

source§

impl<L: Language> SyntaxNodePtr<L>

source

pub fn new(node: &SyntaxNode<L>) -> Self

Returns a SyntaxNodePtr for the node.

Panics if the provided node is mutable

source

pub fn to_node(&self, root: &SyntaxNode<L>) -> SyntaxNode<L>

Like Self::try_to_node but panics instead of returning None on failure.

source

pub fn try_to_node(&self, root: &SyntaxNode<L>) -> Option<SyntaxNode<L>>

“Dereferences” the pointer to get the SyntaxNode it points to.

Returns None if the node is not found, so make sure that the root syntax tree is equivalent to (i.e. is build from the same text from) the tree which was originally used to get this SyntaxNodePtr.

Also returns None if root is not actually a root (i.e. it has a parent).

NOTE: If this function is called on a mutable tree, it will panic

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!

source

pub fn cast<N: AstNode<Language = L>>(self) -> Option<AstPtr<N>>

Casts this to an AstPtr to the given node type if possible.

source

pub fn kind(&self) -> L::Kind

Returns the kind of the syntax node this points to.

source

pub fn text_range(&self) -> TextRange

Returns the range of the syntax node this points to.

Trait Implementations§

source§

impl<L: Clone + Language> Clone for SyntaxNodePtr<L>
where L::Kind: Clone,

source§

fn clone(&self) -> SyntaxNodePtr<L>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<L: Debug + Language> Debug for SyntaxNodePtr<L>
where L::Kind: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<N: AstNode> From<AstPtr<N>> for SyntaxNodePtr<N::Language>

source§

fn from(ptr: AstPtr<N>) -> SyntaxNodePtr<N::Language>

Converts to this type from the input type.
source§

impl<L: Hash + Language> Hash for SyntaxNodePtr<L>
where L::Kind: Hash,

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<L: PartialEq + Language> PartialEq for SyntaxNodePtr<L>
where L::Kind: PartialEq,

source§

fn eq(&self, other: &SyntaxNodePtr<L>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<L: Copy + Language> Copy for SyntaxNodePtr<L>
where L::Kind: Copy,

source§

impl<L: Eq + Language> Eq for SyntaxNodePtr<L>
where L::Kind: Eq,

source§

impl<L: Language> StructuralPartialEq for SyntaxNodePtr<L>

Auto Trait Implementations§

§

impl<L> Freeze for SyntaxNodePtr<L>
where <L as Language>::Kind: Freeze,

§

impl<L> RefUnwindSafe for SyntaxNodePtr<L>
where <L as Language>::Kind: RefUnwindSafe,

§

impl<L> Send for SyntaxNodePtr<L>
where <L as Language>::Kind: Send,

§

impl<L> Sync for SyntaxNodePtr<L>
where <L as Language>::Kind: Sync,

§

impl<L> Unpin for SyntaxNodePtr<L>
where <L as Language>::Kind: Unpin,

§

impl<L> UnwindSafe for SyntaxNodePtr<L>
where <L as Language>::Kind: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.