ballerina-grammar
August 26, 2021 ยท View on GitHub
This repository contains the .tmlanguage file describbing the ballerina language grammar. Currently its consumed by the ballerina vscode plugin to provide syntax highlighting for ballerina.
Contributing
As .tmLanguage files which are of plist format are rather hard to read to the human eye ballerina.tmLanguage file is generated from the ballerina.YAML-tmLaguage YAML file.
Any modifications by hand should be done only to this YAML file.
To generate the tmLanguage file,
npm install
npm run build
Generate language files via the scripts
-
ballerina.YAML-tmLanguage
- Run
node extract-keywords.js [path to ballerina-lang/compiler/ballerina-parser/src/main/java/io/ballerina/compiler/internal/parser/LexerTerminals.java] - Update ballerina.YAML-tmLanguage file with changes
- Run
-
ballerina.tmLanguage
- Run
node build-tm.js
- Run
-
ballerina.monarch.json
- Run
node build-monarch.js
- Run
-
prism-ballerina.js
- Run
cd prism && node extract-keywords.js [path to ballerina-lang/compiler/ballerina-parser/src/main/java/io/ballerina/compiler/internal/parser/LexerTerminals.java]
- Run
Add Test Cases
-
First, build the grammar
- Run
npm run build
- Run
-
Generate test snapshot
- Run
node node_modules/vscode-tmgrammar-test/dist/src/snapshot.js -s source.ballerina -g syntaxes/ballerina.tmLanguage -t test/resources/config/<BALLERINA_FILE>
- Run
-
Test snapshot againt the grammar
- Run
node node_modules/vscode-tmgrammar-test/dist/src/unit.js -s source.ballerina -g syntaxes/ballerina.tmLanguage -t test/resources/snapshots/<NAME>.bal.snap(Makesure the snapshot's lines start with//and// SYNTAX TEST "source.ballerina" "description"is added to the top of the snapshot file to enable the test.)
- Run