Skip to content

nojanath/SublimeKSP

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SublimeKSP

A Sublime Text 3/4 plugin for working with and compiling KSP (Kontakt Script Processor) code.

Changes

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

Installation

  • 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

Manual Installation

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 Packagesfolder by selecting Preferences > 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 Automatic​Package​Reloader

Running From Command Line

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

  • 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.

Documentation

See the Wiki on GitHub.

About

Fork of Nils Liberg's SublimeKSP plugin. See README for details.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages