Skip to main content

Root

Struct Root 

Source
pub struct Root<D: Doc> { /* private fields */ }
Expand description

Root of an AST tree that owns the source code and parsed tree structure.

Root acts as the entry point for all AST operations. It manages the document (source code + parsed tree) and provides methods to get the root node and perform tree-wide operations like replacements.

§Generic Parameters

  • D: Doc - The document type that holds source code and language information

§Example

let mut ast = Language::Tsx.ast_grep("let x = 42;");
let root_node = ast.root();

// Perform tree-wide replacements
ast.replace("let $VAR = $VALUE", "const $VAR = $VALUE");
println!("{}", ast.generate());

Implementations§

Source§

impl<D: Doc> Root<D>

Source

pub const fn doc(doc: D) -> Self

Source

pub fn lang(&self) -> &D::Lang

Source

pub fn root(&self) -> Node<'_, D>

The root node represents the entire source

Source

pub fn edit( &mut self, edit: &Edit<<D as Doc>::Source>, ) -> Result<&mut Self, String>

Source

pub fn replace<M: Matcher, R: Replacer<D>>( &mut self, pattern: M, replacer: R, ) -> Result<bool, String>

Source

pub fn adopt<'r>(&'r self, inner: D::Node<'r>) -> Node<'r, D>

Adopt the tree_sitter as the descendant of the root and return the wrapped sg Node. It assumes inner is under the root and will panic at dev build if wrong node is used.

Source§

impl<L: LanguageExt> Root<StrDoc<L>>

Source

pub fn new<S: AsRef<str>>(src: S, lang: L) -> Self

Source

pub fn source(&self) -> &str

Source

pub fn generate(self) -> String

Source§

impl<L: LanguageExt> Root<StrDoc<L>>

Source

pub fn str(src: &str, lang: L) -> Self

Source

pub fn try_new(src: &str, lang: L) -> Result<Self, String>

Source

pub fn get_text(&self) -> &str

Source

pub fn get_injections<F: Fn(&str) -> Option<L>>(&self, get_lang: F) -> Vec<Self>

Trait Implementations§

Source§

impl<D: Clone + Doc> Clone for Root<D>

Source§

fn clone(&self) -> Root<D>

Returns a duplicate 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<D: Debug + Doc> Debug for Root<D>

Source§

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

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

impl<D: Doc> Replacer<D> for Root<D>

Source§

fn generate_replacement(&self, nm: &NodeMatch<'_, D>) -> Underlying<D>

Generate replacement content for a matched node. Read more
Source§

fn get_replaced_range( &self, nm: &NodeMatch<'_, D>, matcher: impl Matcher, ) -> Range<usize>

Determine the exact range of source code to replace. Read more

Auto Trait Implementations§

§

impl<D> Freeze for Root<D>
where D: Freeze,

§

impl<D> RefUnwindSafe for Root<D>
where D: RefUnwindSafe,

§

impl<D> Send for Root<D>

§

impl<D> Sync for Root<D>

§

impl<D> Unpin for Root<D>
where D: Unpin,

§

impl<D> UnsafeUnpin for Root<D>
where D: UnsafeUnpin,

§

impl<D> UnwindSafe for Root<D>
where D: 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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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.