- Syntax Highlighting
- color by token type
- differentiate global/local/parameter variables
- differentiate buildin/def functions
- highlight JSLT in YAML multiline text (">") if first line of text start with
// JSLT
- Line comment code
- Parenthesis Matching
- Code Folding
- Code Auto Format (Ctrl+Alt+L)
- Code Navigation
- Code Outline
- Goto imported File
- Jump to variable declaration
- Jump to function declaration
- Show variable usages
- Show function usages
- Refactoring: rename variables/parameter/functions
- Validations
- error for non-existing file referenced in import
- error for non-existing import alias referenced by function
- error for non-existing function referenced via import alias
- error for undeclared variables
- error for duplicate declared variables
- error for duplicate declared functions
- error for duplicate function parameters
- error for duplicate declared import aliases
- error for duplicate key in object
- warn for call of unknown function
- Syntax Highlighting
- highlight JSLT in multiline strings in Java/Scala/Kotlin files if first line of text start with
// JSLT
- highlight JSLT in multiline strings in Java/Scala/Kotlin files if first line of text start with
- Code Completion
- meaningful error message when an invalid token was detected
- inline docs for buildin-functions
- suggested tokes on Ctrl+Space
- Validations
- warn on unused import alias
- warn on unused variable declaration
- warn on unused function declaration
- warn on unused function parameter
- error if number of parameter in function call does not match function signature
- JSLT execution
- dialog box that allows to select/write an input JSON, a JSLT transformation and shows the output
- apply JSLT from contextmenu (opens the dialog box)
- when used on JSLT-file, submenu with entry and a list of all JSON files in the project (structured by module/directory?)
- when used on JSON-file, submenu with entry and a list of all JSLT files in the project (structured by module/directory?)
The parser code generated from the src/main/grammar/jslt.bnf by grammarKit has to run twice as it does not recognise the Util-Classes, that are compiled later. Therefore, the build is not completely Gradle based and the generated code is checked into Git. Run the "Generate Parser Code" from the context menu of the bnf-file within IntelliJ (twice) before build if the grammar changed.
The build task throws an exception on the buildSearchableOptions
task (Process 'command '.../.gradle/caches/modules-2/files-2.1/com.jetbrains/jbre/jbr_jcef-11_0_14_1-linux-x64-b2043.25/extracted/jbr/bin/java'' finished with non-zero exit value 3
) on the first run.
Execute the task a second time, and it should build.