1.0.2 • Published 10 months ago

@ts-defold/tstl-export-as-global v1.0.2

Weekly downloads
2
License
MIT
Repository
github
Last release
10 months ago

tstl-export-as-global-plugin

TypeScriptToLua plugin that transforms exports into globals

Config

"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 to
  • globals: object that defines what to match to apply export transformations to
    • functions: array of names to match for export functions to expose as global
    • ...: PR welcome for matching constans, variables, etc if you need support.

Features

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.

1.0.2

10 months ago

1.0.1

10 months ago

1.0.0

3 years ago

0.0.4

4 years ago

0.0.3

4 years ago

0.0.2

4 years ago

0.0.1

4 years ago