tree-sitter/docs/index.md
Andrew Hlynskyi c26dde0414
Merge pull request #1947 from hickford/patch-3
docs: explain naming convention for bindings and parsers
2023-04-04 18:37:18 +03:00

9.5 KiB

title
Introduction

Introduction

Tree-sitter is a parser generator tool and an incremental parsing library. It can build a concrete syntax tree for a source file and efficiently update the syntax tree as the source file is edited. Tree-sitter aims to be:

  • General enough to parse any programming language
  • Fast enough to parse on every keystroke in a text editor
  • Robust enough to provide useful results even in the presence of syntax errors
  • Dependency-free so that the runtime library (which is written in pure C) can be embedded in any application

Language Bindings

There are currently bindings that allow Tree-sitter to be used from the following languages:

By convention, bindings are named with the language first, eg. ruby-tree-sitter.

Parsers

By convention, parsers are named with the language last, eg. tree-sitter-ruby.

Talks on Tree-sitter

Underlying Research

The design of Tree-sitter was greatly influenced by the following research papers: