Exposes an api function that can be used to get a parse tree node for a given file location.
Can be used as follows:
const parseTreeExtension = vscode.extensions.getExtension("pokey.parse-tree");
if (parseTreeExtension == null) {
throw new Error("Depends on pokey.parse-tree extension");
}
const { getNodeAtLocation } = await parseTreeExtension.activate();
Don't forget to add an extensionDependencies
-entry to package.json
as
described in
https://code.visualstudio.com/api/references/vscode-api#extensions.
If you'd like to add support for a new language, see the Adding a new language section below. Alternatively, your extension can register a custom language with this extension. Although this is not the preferred way to add a new language, it can be convenient when you have a parser that you don't believe belongs in the main extension.
Parsing your own language is as simple as registering your languageId
with an absolute path to your .wasm
file:
const { registerLanguage } = await parseTreeExtension.activate();
registerLanguage(languageId, wasmPath);
yarn
It's straightforward to add any language with a tree-sitter grammar.
yarn add -D tree-sitter-yourlang
../src/extension.ts
onLanguage:yourlang
to the activationEvents section of package.json. yourlang
must be a VSCode language identifier.yarn compile
, then hit F5
in VSCode, with this project open, to test your changes.When working with WSL, the host vscode instance connects to a vscode server on the WSL vm. This happens automatically when you run "code" in WSL, as long as you have the "Remote - WSL" extension installed on the host. From there you need to:
pokey.command-server
extension on the host vscodevscode-parse-tree
, you need to clone that as well, build it, and link it into the vscode-server
extension folder: ln -s ~/your/code/vscode-parse-tree ~/.vscode-server/extensions/parse-tree
for instance.Remote-WSL
extension, you might need to manually delete the extension from the host side and try again.web-tree-sitter
We build a custom version of web-tree-sitter
to ensure that we can always use the latest version and fix any problems as they come up.
To update web-tree-sitter
update the contents of ./tree-sitter-version to the latest commit sha of tree-sitter.
The script which builds our custom version is at the end of our Makefile
.
See CHANGELOG.md.
Forked from https://github.com/georgewfraser/vscode-tree-sitter.