NAME

Text::Treesitter - Perl binding for tree-sitter

SYNOPSIS

use Text::Treesitter;

my $ts = Text::Treesitter->new(
   lang_name => "perl",
);

my $tree = $ts->parse_string( $input );

my $root = $tree->root_node;

...

DESCRIPTION

This module provides several classes and utilities that wrap the tree-sitter parser library. A toplevel class is provided by this module which wraps the functionallity of several other classes, which are also available directly in the following modules:

CONSTRUCTOR

new

$ts = Text::Treesitter->new( %params );

Returns a new Text::Treesitter instance. Takes the following named parameters:

lang => Text::Treesitter::Language

Optional. An instance of Text::Treesitter::Language to use in the parser.

lang_name => STRING

Optional. Gives the short name of the tree-sitter language grammar.

Exactly one of lang or lang_name must be provided.

lang_lib => STRING

Gives the path to the compiled object file which contains the language grammar. Optional; if not provided it will be presumed to be named based on the language name, as tree-sitter-$LANG.so within the language directory. If the path does not contain a / character, it will have the language directory path prepended onto it.

lang_dir => STRING

Gives the directory name in which to find the compiled object file which contains the language grammar, or the sources to build it from.

If not specified, a search will be made for a directory named tree-sitter-$LANG among any of the user's configured parser directories, as given by the tree-sitter config file.

METHODS

treesitter_config

$config = Text::Treesitter->treesitter_config;

Returns a data structure containing the user's tree-sitter config, parsed from $HOME/.config/tree-sitter/config.json if it exists. If there is no file then undef is returned.

This is usable as a class method.

parser

$parser = $ts->parser;

Returns the Text::Treesitter::Parser instance being used. The constructor ensures that this will have a language set on it.

lang

$lang = $ts->lang;

Returns the Text::Treesitter::Language instance being used by the parser.

lang_dir

$dir = $ts->lang_dir;

Returns the directory path to the language directory. This is either the configured path that was set by the lang_dir parameter, or discovered by searching if one was not.

parse_string

$tree = $ts->parse_string( $str );

Parses a given input string using the internal parser, returning a node tree as an instance of Text::Treesitter::Tree.

parse_string_range

$tree = $ts->parse_string_range( $str, %options );

Since version 0.10.

Parses a given input string using the internal parser, within the given byte range. Returns a node tree as an instance of Text::Treesitter::Tree.

Takes the following named options:

start_byte
end_byte

The start and end position within the string, in byte counts.

start_row
start_column

Since version 0.11.

Optionally, the logical position within the original source that corresponds to the start byte. These values don't affect parsing as such, but will be reflected in the position offsets of the nodes in the returned tree.

node

Since version 0.11.

Alternative to specifying the four values given above, where they are all taken from the given Text::Treesitter::Node instance directly.

parse_file

$tree = $ts->parse_file( $path );

Since version 0.13.

Reads the file content as a string, then applies "parse_string" on it.

load_query_string

$query = $ts->load_query_string( $str );

Creates a Text::Treesitter::Query instance by compiling the match patterns given in the source string for the language used by the parser.

query_file_path

$path = $ts->query_file_path( $name );

If a file exists of the given path, then it is returned directly. Otherwise, returns a path within the language directory given by lang_dir; either directly or within a subdirectory called queries/.

load_query_file

$query = $ts->load_query_file( $name );

Creates a Text::Treesitter::Query instance by loading the text from the given path, and then compiling it as per "load_query_string". The name is resolved into a path by using "query_file_path".

TODO

The following C library functions are currently unhandled:

the entire TSTreeCursor API

AUTHOR

Paul Evans <leonerd@leonerd.org.uk>