You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Any non-trivial Lua code quickly turns into a mess of unexpected behavior, half-broken error handling, and other kinds of runtime errors. A robust typing system can allow the compiler or linter to statically check if the data passes has correct shape, preventing such bugs, helping create more reliable software and waste less time debugging.
Both OpenComputers and its users would greatly benefit from maintaining official typing hints.
Implementation details
The main approaches to static typing in Lua are EddyLua typing hints and Teal.
Teal
A statically typed dialect of Lua that compiles to it, similar to what TypeScript is to JavaScript. Uses declaration files to add typing to imported code, including that which used FFI.
A Teal program must have valid types to compile.
Example:
localrecordMyCompositeTyperecordMyPointTypex: numbery: numberendcenter: MyPointType-- insert more stuff hereendreturnMyCompositeType
EmmyLua
EmmyLua is an adhoc spec for typing hint comments, first started by the same named JetBrains plugin but later adopted by LuaLS/lua-language-server, becoming the typical way to add basic type linting to Lua code.
Because it functions as a linter, nothing prevents the user from running the invalidly typed code but their IDE will report the issue.
To add typing to some module that lives on the other side of the FFI, you'll need to create a stub, an empty placeholder with the typing hints.
Example:
---@classitem---@fieldpublicdamage number the current damage value of the item.---@fieldpublicmaxDamage number the maximum damage this item can have before it breaks.---@fieldpublicsize number the current stack size of the item.---@fieldpublicmaxSize number the maximum stack size of this item.---@fieldpublicid number the Minecraft id of the item. Note that this field is only included if insertIdsInConverters=true in the configs, and can vary between servers!---@fieldpublicname string the untranslated item name, which is an internal Minecraft value like oc:item.FloppyDisk---@fieldpubliclabel string the translated item name---@fieldpublichasTag boolean whether or not the item has an NBT tag associated with it.localitem={}
While I understand the maintainers may have quite little time on their hands to dedicate to this project and this may not seem like an important issue, I believe this kind of static analysis is imperative to ensuring proper developer experience. Dynamic typing can be very very frustrating once your program grows from a tiny script you can keep in mind to a mid-size codebase; this simple documentation effort holds the key to reduce this frustration, including aiding in maintenance of OpenComputers Lua assets themselves.
If anyone has the time and patience to manually write such annotations or generate them from ocdoc.cil.li, please let yourselves be known. Such documentation efforts should be folded into the OpenComputers project so it can stay standardized and up to date.
The text was updated successfully, but these errors were encountered:
This sounds like a good idea, with the minor caveat that increasing .lua file size directly adds to the hard drive usage in OpenComputers; adding too many annotations to the OS itself may prompt a need to rebalance the mod's default hard disk sizes.
Ideally, it would be ocdoc.cil.li pages and mod-bundled Markdown documentation which are generated from such annotations.
Motivation
Any non-trivial Lua code quickly turns into a mess of unexpected behavior, half-broken error handling, and other kinds of runtime errors. A robust typing system can allow the compiler or linter to statically check if the data passes has correct shape, preventing such bugs, helping create more reliable software and waste less time debugging.
Both OpenComputers and its users would greatly benefit from maintaining official typing hints.
Implementation details
The main approaches to static typing in Lua are EddyLua typing hints and Teal.
Teal
A statically typed dialect of Lua that compiles to it, similar to what TypeScript is to JavaScript. Uses declaration files to add typing to imported code, including that which used FFI.
A Teal program must have valid types to compile.
Example:
EmmyLua
EmmyLua is an adhoc spec for typing hint comments, first started by the same named JetBrains plugin but later adopted by LuaLS/lua-language-server, becoming the typical way to add basic type linting to Lua code.
Because it functions as a linter, nothing prevents the user from running the invalidly typed code but their IDE will report the issue.
To add typing to some module that lives on the other side of the FFI, you'll need to create a stub, an empty placeholder with the typing hints.
Example:
Prior works:
End note:
While I understand the maintainers may have quite little time on their hands to dedicate to this project and this may not seem like an important issue, I believe this kind of static analysis is imperative to ensuring proper developer experience. Dynamic typing can be very very frustrating once your program grows from a tiny script you can keep in mind to a mid-size codebase; this simple documentation effort holds the key to reduce this frustration, including aiding in maintenance of OpenComputers Lua assets themselves.
If anyone has the time and patience to manually write such annotations or generate them from ocdoc.cil.li, please let yourselves be known. Such documentation efforts should be folded into the OpenComputers project so it can stay standardized and up to date.
The text was updated successfully, but these errors were encountered: