Factorio Auxiliary DocsVersion 2.0.28

Instrument Mode

Instrument Mode gives a mod the ability to inject extra code very early on in all Lua states. At most one mod may be enabled in Instrument Mode, using the command line argument --instrument-mod modname. This is intended to be used to provide mod development tools and other instrumentation, in combination with the Lua debug library and the LuaProfiler. Multiplayer is disabled while an Instrument Mode mod is in use, as it is not desync-safe. The following additions to the usual Data Lifecycle apply:

1. The settings stage

If the Instrument Mode mod has an instrument-settings.lua file, it is loaded before all other mods. The settings stage then proceeds as normal.

2. The data stage

If the Instrument Mode mod has an instrument-data.lua file, it is loaded before all other mods. The data stage then proceeds as normal. If the Instrument Mode mod has an instrument-after-data.lua file, it is loaded after all other mods have completed their data-final-fixes.lua stage.

3. control.lua initialization

If the Instrument Mode mod has an instrument-control.lua file, it is loaded in every mod's Lua state before their own control.lua file. The control stage then proceeds as normal.

on_error

In all three instrument files, the additional global function on_error(f) may be used to register an error handler for that Lua state. The handler receives the thrown error object (a LocalisedString) and may return a LocalisedString to be added to the displayed error message.