TES3MP scripts are written in Lua (specifically LuaJIT 5.1).
If you are completely new to programming, I recommend you read through the entirety of Programming in Lua.
If you are an experienced programmer, but are not an expert in Lua, there a few peculiar parts of the language you should check out:
- Basic types for example, there are no traditional arrays in Lua, instead there is a set of conventions for tables (referred to as "array" in the following chapters)
- Coroutines a very powerful way to implement generators and asynchronicity
- OOP object-oriented programming approach similar to JavaScript prototypes
- Closures a very useful detail of variable scopes in Lua
Integration with the TES3MP server itself happens mostly through calls to a lua binding available as a global table tes3mp
. You can find the current documentation here. However for most of the use cases there are higher level functions available in CoreScripts, and you should strive to use those as much as possible.
Additionally, the server calls Lua code directly through Events and Timers.
The main server applications only receives and sends packets. Most of the logic is performed by CoreScripts.
Most of your scripts will only execute code inside an event, a timer, or a chat command, so regardless of your goals and experience, start with understanding how these work.
Currently, the process of installing a custom script by the end user consists of adding require statements to the customScripts.lua
file.
Thus you want to minimize the amount of files that must be require
d. For smaller scripts that can be achieved simply by putting all of your code in a single file, but for larger ones you might want to have a file that requires the others, assembling your script into a single module.
It is generally a good practice to form each of your scripts as a single table, and then return
it. This way you don't pollute global variable space and make it easier for other scripts to reuse your code.
As a quick introduction, take a look at examples.
Consider joining the TES3MP Discord server. There you will find:
#scripting_help
here you can ask questions about writing TES3MP server scripts#custom_scripts
a catalogue of existing scripts. Use them as advanced examples, or maybe add your own scripts to the list!