GNU bug report logs -
#72691
Recursive descent in treesiter parse tree
Previous Next
Full log
View this message in rfc822 format
> On Aug 18, 2024, at 7:57 AM, Pranshu Sharma <pranshusharma198 <at> gmail.com> wrote:
>
> Ok, I found the solution: you have to capture witha function and traverse the whole tree recursively
As you’ve found out, tree-sitter’s query system doesn’t support the feature you want (it’ll be quite expensive to implement, I think). Even if you’ve found a solution, if you want, maybe you can describe your actual use-case and I can check if your solution is the most optimal.
Yuan
>
> On Sun, 18 Aug 2024, 7:24 pm Eli Zaretskii, <eliz <at> gnu.org> wrote:
> > From: Pranshu Sharma <pranshusharma198 <at> gmail.com>
> > Date: Sun, 18 Aug 2024 14:57:10 +1000
> >
> > I am trying to write a major mode in which all instances of a node in another matched node. For this, recursion
> > is needed, and for that it is necessary to store a match in a variable:
> > Say I want to highlight all instances of (x) that are inside y in the following parse tree, where bolded means I
> > want to match:
> > (x) in (q (y (x) (l (x) (l (x) (p))) (x))
> >
> > "(y) @test
> > @test . (_) @font-lock-variable-name-face"
> > "(y) @test
> > (@test . (_) @font-lock-variable-name-face)"
> > "(y) @test
> > (test . (_) @font-lock-variable-name-face)"
> >
> > All of the above fail, which leads me to think that @test stores the text instead of the tree. In this case, how
> > would I recursively match all instances of
>
> Adding Yuan.
This bug report was last modified 265 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.