A tool to build Stormworks addons with ease.
See below for what this tool can do thanks to utilizing SelenScript.
This project is still work in progress, however it is usable and worth giving a try.
There are many features still to be added, but already provides more than alternate options.
Currently, only addon Lua is supported, it is planned to support vehicle Lua in the future.
The following is what this tool provides:
- Combining multiple files into one.
- Optional tracing which provides full stack traces at runtime with source file, line and column info.
- Single and Multi project config files.
- Specify output paths to automatically update addon scripts.
- Custom build actions (see below for using build actions)
- Intellisense information (from Cuh4/StormworksAddonLuaDocumentation)
watch
command to re-build automatically upon changes.- TODO: vscode task template.
- TODO: Additional configurable options (changing emitter config).
Note that Linux is not supported properly yet, but should be in the future.
MacOS will not be officially supported, but if you have any issues feel free to make an issue on this repo.
See the releases for download.
If you want to use ssswtool
from anywhere, consider adding it to your PATH (the directory containing ssswtool.bat
).
See usage for how to use this tool.
Requires to be run in a cmd prompt.
If ssswtool
was added to your PATH, you can use ssswtool
directly, otherwise replace it with the path to ssswtool.bat
.
- Create a new project with
ssswtool new addon ./some_addon_name
. - Enter the new directory
cd ./some_addon_name
. - Edit
script.lua
, any filesrequire
d from here will be included into the output. - Build with
ssswtool build ./
.
The default output directory is<PROJECT_DIR>/_build/script.lua
.
It will also output to<SW_SAVEDATA>/data/missions/<PROJECT_NAME>/script.lua
if the directory exists.
You may edit ssswtool.json
to customize the build process, see below.
You may use ssswtool watch ./
, which will re-build your addon automatically when any changes are detected.
Do be careful when modifying ssswtool.json
while watch
is running.
You will also see intellisense.lua
which is automatically downloaded from Cuh4/StormworksAddonLuaDocumentation, this is used for typing information.
If you want to update this file you can safely re-run ssswtool new addon ./
in the project's directory to update this file.
This section describes the format of ssswtool.json
and any referenced configs by it.
NOTE that comments are not supported, they must be removed from the examples to utilize them.
Basic usage example (values represent default)
{
// "name" defaults to the containing directory name if not provided.
"name": "some_addon",
// "entrypoint" defaults to "script.lua" if not provided.
"entrypoint": "script.lua",
// Required, specifies where to look for entrypoint and for `require()`
// This can be an array, eg [".", "/PATH/TO/SOME/LIB"]
"src": ".",
"transformers": {
// The combiner makes `require()` work by including files and providing a custom
// implementation of `require()`, which works similar to standalone Lua.
"combiner": true,
// Tracing add compile time tracing information which is used to
// generate stack traces with correct file names and line numbers in-game.
// This should be `false` for releases
// as it affects runtime performance and will greatly impact the output size.
// Possible options: false, "simple" and "full"
"tracing": false
}
}
Multi-Project and config reference example
// Multi project configs start with an array.
[
// Refer to another project's config.
// It doesn't strictly need to be named `ssswtool.json`, but it is highly recommended to be.
"./other_project/ssswtool.json",
// Or just provide a normal config.
{
// "name" becomes a required field.
"name": "some_addon",
"src": ".",
"transformers": {
"combiner": true,
"tracing": false
}
}
]
DO NOT USE CODE YOU DON'T TRUST! It is your responsibility to ensure this.
Build actions are run within SSSWTool without sandboxing, as such has the same capabilities.
To get started with build actions, run ssswtool new buildactions ./
in the project directory.
You will now have a folder _buildactions
which should contain all of your future build actions code.
Build actions run the file _buildactions/init.lua
, the default file contains additional info you may need.
Note that build actions may be run frequently and with partially written code when using the watch
CLI action.
SSSWTool build actions are not compatible with LifeBoatAPI and will never be.
A simple user config is stored at %appdata%/.ssswtool.json
Currently, this is only used for storing whitelisted directories for build actions and if updates to intellisense info is checked.
Releases contain luajit
pre-built for windows x64 (deleting it will use system version instead).
The following can be found in SelenScript/libs
:
- lfs
/luafilesystem
- lpeglabel
(See this repo for modifications)
- luanotify
- luasocket