sm64coopdx/docs/lua/lua.md
EmeraldLockdown 7e10a3bb13
Add in C documentation (#1176)
* Add in C documentation

* update readme

* Remove unecessary spacing
2026-04-21 21:35:01 -04:00

3.3 KiB

Lua Reference

How to install Lua mods

Lua scripts you make can be placed either the mods folder in the base directory, or in <SAVE FILE LOCATION>/mods. You can also drag and drop mods into the window to install them.

Save file locations:

  • Windows: %appdata%/sm64coopdx
  • Linux: ~/.local/share/sm64coopdx
  • MacOS: ~/Library/Application Support/sm64coopdx

Tips

  • When developing Lua mods, run the game from a console. Lua errors and logs will appear there, but only if the game is launched with the --console launch parameter.
  • When a function requests a time parameter, it is almost if not always in frames.
  • You can use the print() command when debugging. Your logs will show up in the console.
  • You can create a folder within the mods folder containing multiple lua scripts as long as one script is called main.lua. Dynos actors can be placed inside this mod folder under <your mod folder>/actors/.

Sections

Guides

Important notes on player indices

Something important to realize is that the localIndex for each player is different (unfortunately).

So the order of gMarioStates[], gNetworkPlayers[], and gPlayerSyncTable[] is different for each player.

Luckily gPlayerSyncTable[] will automatically translate the player indices, so setting gPlayerSyncTable[0].example = 1 will set it for the correct player for everyone.

The globalIndex of each player is consistent among everyone connected. So if you absolutely need to sort things in order you will have to grab it from gNetworkPlayers[<LOCAL INDEX HERE>].globalIndex.

All of this is a holdover from when there were only two players. It was a reasonable idea back then.


Example Lua mods (small)

Example Lua mods (large)