TypeScriptToLua plugin that transforms exports into globals
"tstl": {
"luaPlugins": [
{
"name": "@ts-defold/tstl-export-as-global",
"match": ".*script.ts$",
"globals": {
"functions": [ "init", "on_input", "on_message", "on_reload", "update", "final"]
}
}
]
}
The config accpets some additional arguments that are required to make this plugin work.
match
: regex pattern of file names to match to apply export transformations toglobals
: object that defines what to match to apply export transformations tofunctions
: array of names to match for export functions to expose as global...
: PR welcome for matching constans, variables, etc if you need support.
Transform this TypeScript (with config values from above):
function no_export() {
"not-exported";
}
export function init() {
no_export();
"init";
}
export function update(dt: number) {
const val = dt * 100;
val * val;
}
export function exported() {
"exported";
}
To this lua:
--[[ Generated with https://github.com/TypeScriptToLua/TypeScriptToLua ]]
local ____exports = {}
local function no_export(self)
local ____ = "not-exported"
end
function ____exports.init(self)
no_export(nil)
local ____ = "init"
end
function ____exports.update(self, dt)
local val = dt * 100
local ____ = val * val
end
function ____exports.exported(self)
local ____ = "exported"
end
init = ____exports.init
update = ____exports.update
Any function marked for export is now exposed to the global (file) scope. This plugin was created to expose functions to file scope for the Defold runtime where the runtime expects to call these functions.