Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/langston-barrett/tree-sitter-souffle
A tree-sitter grammar for Soufflé Datalog
https://github.com/langston-barrett/tree-sitter-souffle
datalog parsing souffle tree-sitter
Last synced: 3 months ago
JSON representation
A tree-sitter grammar for Soufflé Datalog
- Host: GitHub
- URL: https://github.com/langston-barrett/tree-sitter-souffle
- Owner: langston-barrett
- License: mit
- Created: 2022-10-21T22:17:17.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-07-13T07:04:17.000Z (7 months ago)
- Last Synced: 2024-10-10T16:35:31.739Z (4 months ago)
- Topics: datalog, parsing, souffle, tree-sitter
- Language: C
- Homepage:
- Size: 434 KB
- Stars: 13
- Watchers: 3
- Forks: 2
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# tree-sitter-souffle
![crates.io](https://img.shields.io/crates/v/tree-sitter-souffle.svg)
A [tree-sitter][tree-sitter] grammar for [Soufflé][souffle].
## Contents
**Table of Contents**
- [tree-sitter-souffle](#tree-sitter-souffle)
- [Contents](#contents)
- [Status](#status)
- [Use-Cases](#use-cases)
- [On the C Pre-Processor](#on-the-c-pre-processor)
- [Design](#design)
- [Development](#development)
- [Tests](#tests)
- [References](#references)
- [Releasing](#releasing)## Status
The grammar is fairly complete. It parses:
- 500/503 test cases from the Soufflé repo (v2.3)
- [ddisasm][ddisasm]
- The [Soufflé benchmarks][benchmarks]There are a few [known issues][bugs].
## Use-Cases
This grammar aims to support the following use-cases:
- Editor integration
- Code navigation (e.g., jump-to-definition, show references)
- Syntax highlighting
- Evaluation
- Linting
- Static analysisIt does *not* currently aim to support round-trip printing (i.e., code
formatting and refactoring).## On the C Pre-Processor
This parser has limited support for parsing C pre-processor `#line` directives,
which may be helpful for analysis tasks. To avoid over-complicating the grammar,
it does not handle directives in the middle of top-level entities (e.g., in
between two conjuncts of a rule). You can configure your preprocessor to not
emit such tokens (`-P` for `mcpp`).## Design
The grammar doesn't mirror the structure of the Soufflé C++ parser
implementation nor the grammar as presented in the Soufflé documentation. It
instead tries to map nonterminals to more abstract categories, i.e., categories
that match the way we think about the language. For instance, the Soufflé C++
parser doesn't have a nonterminal for constants, whereas this parser does. As
another example, the Soufflé documentation has this specification for type
declarations:```
type_decl ::= '.type' IDENT ("<:" type_name | "=" ( type_name ( "|" type_name )* | record_list | adt_branch ( "|" adt_branch )* ))
```
This grammar instead has something more like
```javascript
type_decl ::= subtype | type_synonym | type_union | record | adt
```
so that the parse tree encodes a bit more "semantic" information. The hope is
that these choices make it easier to write [tree-sitter queries][queries].For the same reason, the grammar doesn't specify keywords and operators like
`.functor`, `eqrel`, `*`, and `:-` as their own nonterminals, but rather inlines
them into the grammar.## Development
### Tests
Run
```bash
tree-sitter test
```
or equivalently
```
npm test
```This script downloads the Soufflé, ddisasm, cclyzer++, and other repos and attempts to parse their Datalog files.
```
./scripts/parse-examples
```### References
- [Soufflé Documentation](https://souffle-lang.github.io/program#program)
- [Soufflé Parser](https://github.com/souffle-lang/souffle/blob/master/src/parser/parser.yy)### Releasing
1. Update [`CHANGELOG.md`](./CHANGELOG.md)
2. Update the version number in [`Cargo.toml`](./Cargo.toml)
3. `git checkout main && git pull origin && git tag -a vX.Y.Z -m vX.Y.Z && git push --tags`
4. `cargo publish`
5. Release the pre-release created by CI[bugs]: https://github.com/langston-barrett/tree-sitter-souffle/issues?q=is%3Aissue+is%3Aopen+label%3Abug
[benchmarks]: https://github.com/souffle-lang/benchmarks/
[ddisasm]: https://github.com/grammatech/ddisasm
[queries]: https://tree-sitter.github.io/tree-sitter/using-parsers#pattern-matching-with-queries
[souffle]: https://souffle-lang.github.io/index.html
[tree-sitter]: https://tree-sitter.github.io/tree-sitter/