plexgram-swift
v0.20.9
Published
Swift grammar for tree-sitter
Downloads
3
Readme
tree-sitter-swift
This contains a tree-sitter
grammar for the Swift programming language.
Getting started
To use this parser to parse Swift code, you'll want to depend on either the Rust crate or the NPM package.
Rust
To use the Rust crate, you'll add this to your Cargo.toml
:
tree-sitter = "0.20.4"
tree-sitter-swift = "=0.3.6"
Then you can use a tree-sitter
parser with the language declared here:
let mut parser = tree_sitter::Parser::new();
parser.set_language(tree_sitter_swift::language())?;
// ...
let tree = parser.parse(&my_source_code, None)
.ok_or_else(|| /* error handling code */)?;
Javascript
To use this from NPM, you'll add similar dependencies to package.json
:
"dependencies: {
"tree-sitter-swift": "0.3.6",
"tree-sitter": "^0.20.0"
}
Your usage of the parser will look like:
const Parser = require("tree-sitter");
const Swift = require("tree-sitter-swift");
const parser = new Parser();
parser.setLanguage(Swift);
// ...
const tree = parser.parse(mySourceCode);
Editing the grammar
With this package checked out, a common workflow for editing the grammar will look something like:
- Make a change to
grammar.ts
. - Run
npm install && npm test
to see whether the change has had impact on existing parsing behavior. The defaultnpm test
target requiresvalgrind
to be installed; if you do not have it installed, and do not wish to, you can substitutetree-sitter test
directly. - Run
tree-sitter parse
on some real Swift codebase and see whether (or where) it fails. - Use any failures to create new corpus test cases.
Contributions
If you have a change to make to this parser, and the change is a net positive, please submit a pull request. I mostly
started this parser to teach myself how tree-sitter
works, and how to write a grammar, so I welcome improvements. If
you have an issue with the parser, please file a bug and include a test case to put in the corpus
. I can't promise any
level of support, but having the test case makes it more likely that I want to tinker with it.
Using tree-sitter-swift in Web Assembly
To use tree-sitter-swift as a language for the web bindings version tree-sitter, which will likely be a more modern version than the published node module. see. Follow the instructions below
- Install the node modules
npm install web-tree-sitter tree-sitter-swift
- Run the tree-sitter cli to create the wasm bundle
$ npx tree-sitter build-asm ./node_modules/tree-sitter
- Boot tree-sitter wasm like this.
const Parser = require("web-tree-sitter");
async function run(){
//needs to happen first
await Parser.init();
//wait for the load of swift
const Swift = await Parser.Language.load('./tree-sitter-swift.wasm');
const parser = new Parser();
parser.setLanguage(Swift);
//Parse your swift code here.
const tree = parser.parse('print("Hello, World!")')
}
//if you want to run this
run().then(console.log, console.error);
Frequently asked questions
Where is your parser.c
?
This repository currently omits most of the code that is autogenerated during a build. This means, for instance, that
grammar.json
and parser.c
are both only available following a build. It also significantly reduces noise during
diffs.
The side benefit of not checking in parser.c
is that you can guarantee backwards compatibility. Parsers generated by
the tree-sitter CLI aren't always backwards compatible. If you need a parser, generate it yourself using the CLI; all
the information to do so is available in this package. By doing that, you'll also know for sure that your parser version
and your library version are compatible.
If you need a parser.c
, and you don't care about the tree-sitter version, but you don't have a local setup that would
allow you to obtain the parser, you can just download one from a recent workflow run in this package. To do so:
- Go to the GitHub actions page for this repository.
- Click on the "Publish
grammar.json
andparser.c
" action for the appropriate commit. - Go down to
Artifacts
and click ongenerated-parser-src
. All the relevant parser files will be available in your download.