What's New in LUA Modding: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
|||
Line 37: | Line 37: | ||
"lua": "-- Description is called when an object's description is shown to the\r\n-- player or otherwise requested. The object should return a string\r\n-- containing the description.\r\n\r\nfunction description()\r\n\r\n -- Create a descriptive string\r\n local descriptiveText = \"The gem shines programatically as you look at it.\";\r\n\r\n -- Return it\r\n return descriptiveText;\r\n\r\nend" | "lua": "-- Description is called when an object's description is shown to the\r\n-- player or otherwise requested. The object should return a string\r\n-- containing the description.\r\n\r\nfunction description()\r\n\r\n -- Create a descriptive string\r\n local descriptiveText = \"The gem shines programatically as you look at it.\";\r\n\r\n -- Return it\r\n return descriptiveText;\r\n\r\nend" | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight>Because of this change, I've disabled the lua field in the mod upload/edit page to avoid needless duplication. | ||
== Access to more utility functions/classes == | == Access to more utility functions/classes == | ||
A number of new classes are available, check out the [[:Category:LUA Class Reference|API reference]]. | |||
== Optional parameters == | |||
A few functions have since been updated to support optional parameters, like silent TFs. |
Revision as of 05:13, 18 July 2023
Inputting LUA
You no longer need to manually compile LUA into bytecode and then base64 it! Now you simply escape the lua source code and drop it in.
Note the field changed from 'luac' (compiled lua) to just 'lua'
Example
Previously mod json in AS3:
{
"type": "ENTITY",
"name":
{
"literalString" : "Shinier Gem"
},
"description":
{
"programString": true
},
"luac": "G0x1YVEAAQQEBAgAEAAAAEBzaGluaWVyR2VtLmx1YQAAAAAAAAAAAAAAAgIDAAAAJAAAAAcAAAAeAIAAAQAAAAQMAAAAZGVzY3JpcHRpb24AAQAAAAAAAAAFAAAADQAAAAAAAAIDAAAAAQAAAB4AAAEeAIAAAQAAAAQyAAAAVGhlIGdlbSBzaGluZXMgcHJvZ3JhbWF0aWNhbGx5IGFzIHlvdSBsb29rIGF0IGl0LgAAAAAAAwAAAAgAAAALAAAADQAAAAEAAAAQAAAAZGVzY3JpcHRpdmVUZXh0AAEAAAACAAAAAAAAAAMAAAANAAAABQAAAA0AAAAAAAAAAAAAAA=="
}
And now mod json in new engine:
{
"type": "ENTITY",
"name":
{
"literalString" : "Shinier Gem"
},
"description":
{
"programString": true
},
"lua": "-- Description is called when an object's description is shown to the\r\n-- player or otherwise requested. The object should return a string\r\n-- containing the description.\r\n\r\nfunction description()\r\n\r\n -- Create a descriptive string\r\n local descriptiveText = \"The gem shines programatically as you look at it.\";\r\n\r\n -- Return it\r\n return descriptiveText;\r\n\r\nend"
}
Because of this change, I've disabled the lua field in the mod upload/edit page to avoid needless duplication.
Access to more utility functions/classes
A number of new classes are available, check out the API reference.
Optional parameters
A few functions have since been updated to support optional parameters, like silent TFs.