Skip to content

Write cool features, spend less time debugging common lua mistakes™

License

Notifications You must be signed in to change notification settings

admiralnelson/warhammer3-typescript-framework

Repository files navigation

Warhammer Typescript Framework

Write cool features, spend less time debugging common lua mistakes™
To get started run InstallNodeJSNOW.bat to install required programs for this

To create new project run CreateNewProjectNOW.bat

You can periodically pull this repo to update the project templates.

Caveats

API provided in Typescript is not yet fully complete, but it does capable to make mods like these:

This is taken from https://typescripttolua.github.io/docs/caveats doc

Feature support

Feature Lua 5.0 Lua 5.1 Lua 5.2 Lua 5.3 LuaJIT
Missing features
Bitwise operators ✔️ ✔️ ✔️
continue ✔️* ✔️ ✔️ ✔️
(everything else) ✔️ ✔️ ✔️ ✔️ ✔️

*thru workaround in compile time

Differences from JavaScript

This project aims for both compilation results to have the same behavior as much as possible, but not at all costs. Since TypeScript is based on JavaScript it also inherited some of the quirks in JavaScript that are not present in Lua. This is where behavior between Lua and JavaScript compilation targets diverge. TypeScriptToLua aims to keep identical behavior as long as sane TypeScript is used: if JavaScript-specific quirks are used behavior might differ.

Below are some of the cases where resulting Lua intentionally behaves different from compiled JS.

Type-directed emit

One of TypeScript's design goals is not using type information to affect program runtime behavior. Though this has many advantages (such as gradual typing), TypeScriptToLua uses type information extensively. This allows us to emit a much more optimized, portable, and correct Lua code.

JavaScript and Lua differ in what they evaluate to true/false. TypeScriptToLua adheres to the Lua evaluations.

TypeScript JavaScript behavior Lua behavior
false false false
undefined false false
null false false
NaN false ⚠️true
"" false ⚠️true
0 false ⚠️true
(Everything else) true true

TypeScriptToLua makes no difference between == and === when compiling to Lua, treating all comparisons as strict (===).

Array Length

Array.prototype.length is translated to Lua's # operator. Due to the way lists are implemented in Lua there can be differences between JavaScript's list.length and Lua's #list. The transpiler does not do anything to remedy these differences, so when working with lists, the transpiled Lua will use the standard Lua conventions. Generally speaking, the situation where these differences occur happen when adding/removing items to a list in a hacky way, or when setting list items to undefined/null.

Examples:

Safe (no difference):

const myList = [1, 2, 3];
myList.push(4);
myList.pop();
myList.splice(1, 1);
// myList.length == 2

Differences might occur:

const myList = [1, 2, 3];
myList[1] = undefined;
// myList.length == 1 (3 in JavaScript)
const myList = [1, 2, 3];
myList[4] = 5;
// myList.length == 3 (5 in JavaScript)

Key Iteration Order

Even though iterating over object keys with for ... in does not guarantee order in either JavaScript or Lua. Therefore, the iteration order in JavaScript is likely different from the order in Lua.

Note: If a specific order is required, it is better to use ordered collections like lists instead.

Iterating an array with for ... in

Not allowed.

About

Write cool features, spend less time debugging common lua mistakes™

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published