A Sublime Text 3/4 plugin for working with and compiling KSP (Kontakt Script Processor) code.
This fork is based on Nils Liberg's official SublimeKSP plugin, v1.11, and supports all Kontakt versions. However, there are a number of additions and changes:
- Available in Package Control, which supports automatic updates
- Updates to the syntax highlighting
- Support for Creator Tools GUI Designer
- Numerous additions to the preprocessor, allowing for UI arrays, new macro types and much more
- See the SublimeKSP Added Features section of the Wiki for more information
- Install Package Control
- After installing Package Control and restarting Sublime Text:
- Open the Command Palette from the Tools menu, or by pressing CmdShiftP (macOS) or CtrlShiftP (Windows)
- Type "Install Package"
- Type "KSP" and select "KSP (Kontakt Script Processor)"
- Press Enter to install
- Restart Sublime Text
To use features of SublimeKSP before official package releases:
- If you already had SublimeKSP installed via Package Control, uninstall it before continuing further!
- Locate Sublime Text's
Packages
folder by selectingPreferences > Browse Packages
from the main menu - Clone SublimeKSP repository into this folder via Git (
git clone https://github.com/nojanath/SublimeKSP.git "KSP (Kontakt Script Processor"
) - After pulling the latest changes (
git pull
), reload Sublime Text - If you wish to pull in latest changes without restarting Sublime Text, we recommend installing AutomaticPackageReloader
SublimeKSP compiler can also be ran from command line, by simply executing ksp_compiler.py
with the appropriate source (and optionally output) file path(s),
along with optional compiler switches.
For this, you need to use the manual installation of SublimeKSP, in order to have direct access to ksp_compiler.py
file. To execute a compilation of a file,
it is as simple as typing:
> python ksp_compiler.py "<source-file-path>"
However, various compiler options from SublimeKSP's Tools menu are also available. All of them are set to false if not used, and by including them in the command line, they are set to true:
ksp_compiler.py [-h] [-c] [-v] [-e] [-o] [-t] [-d] source_file [output_file]
positional arguments:
source_file
output_file
optional arguments:
-h, --help show this help message and exit
-f, --force force all specified compiler options, overriding any compile_with pragma directives from the script
-c, --compact remove indents and empty lines in compiled code
-v, --compact_variables shorten and obfuscate variable names in compiled code
-d, --combine_callbacks combines duplicate callbacks - but not functions or macros
-e, --extra_syntax_checks additional syntax checks during compilation
-o, --optimize optimize the compiled code
-b, --extra_branch_optimization adds branch optimization checks earlier in compile process, allowing define constant based branching etc.
-i NUM_SPACES, --indent-size NUM_SPACES specifies how many spaces is used for indentation, if --compact compiler option is not used
-t, --add_compile_date adds the date and time comment atop the compiled code
-x, --sanitize_exit_command adds a dummy no-op command before every exit function call
> python ksp_compiler.py --force -c -e -o "<source-file-path>" "<target-file-path>"
- Updates to the plugin will be automatically installed via Package Control.
- Pull requests are welcome for bugfixes/updates/changes. If you aren't familiar with pull requests, just open an issue here.
See the Wiki on GitHub.