Module LuaHandle

Callins, functions called by the Engine

This page is future looking to unified widget/gadget (aka "addon") handler, which may yet be some way off, c.f. the changelog.

Related Sourcecode: LuaHandle.cpp

For now, to use these addons in a widget, prepend widget: and, for a gadget, prepend gadget:. For example,

function widget:UnitCreated(unitID, unitDefID, unitTeam, builderID)
    ...
end

Some functions may differ between (synced) gadget and widgets; those are in the Synced - Unsynced Shared section. Essentially the reason is that all information should be available to synced (game logic controlling) gadgets, but restricted to unsynced gadget/widget (e.g. information about an enemy unit only detected via radar and not yet in LOS). In such cases the full (synced) param list is documented.

Attention: some callins will only work on the unsynced portion of the gadget. Due to the type-unsafe nature of lua parsing, those callins not firing up might be hard to trace. This document will be continuously updated to properly alert about those situations.


See also:

Teams

TeamDied
Called when a team dies (see Spring.KillTeam).
TeamChanged
PlayerChanged
Called whenever a player's status changes e.g.
PlayerAdded
Called whenever a new player joins the game.
PlayerRemoved
Called whenever a player is removed from the game.

Projectiles

ProjectileCreated
Called when the projectile is created.
ProjectileDestroyed
Called when the projectile is destroyed.
Explosion
Called when an explosion occurs.
StockpileChanged
Called when a units stockpile of weapons increases or decreases.
RecvLuaMsg
Receives messages from unsynced sent via Spring.SendLuaRulesMsg or Spring.SendLuaUIMsg.
Save
Called when a chat command '/save' or '/savegame' is received.
UnsyncedHeightMapUpdate
Called when the unsynced copy of the height-map is altered.
Update
Called for every draw frame (including when the game is paused) and at least once per sim frame except when catching up.
ViewResize
Called whenever the window is resized.
FontsChanged
Called whenever fonts are updated.
SunChanged
DefaultCommand
Used to set the default command when a unit is selected.

Features

FeatureCreated
Called when a feature is created.
FeatureDestroyed
Called when a feature is destroyed.
FeatureDamaged
Called when a feature is damaged.

Common

Initialize
Called when the addon is (re)loaded.
LoadCode
Called when the game is (re)loaded.
Shutdown
Called when the addon or the game is shutdown.
GotChatMsg
Called when a player issues a UI command e.g.
Load
Called after GamePreload and before GameStart.

Game

GamePreload
Called before the 0 gameframe.
GameStart
Called upon the start of the game.
GameOver
Called when the game ends
GamePaused
Called when the game is paused.
GameFrame
Called for every game simulation frame (30 per second).
GameFramePost
Called at the end of every game simulation frame
GameID
Called once to deliver the gameID

Units

UnitCreated
Called at the moment the unit is created.
UnitFinished
Called at the moment the unit is completed.
UnitFromFactory
Called when a factory finishes construction of a unit.
UnitReverseBuilt
Called when a living unit becomes a nanoframe again.
UnitConstructionDecayed
Called when a unit being built starts decaying.
UnitDestroyed
Called when a unit is destroyed.
UnitTaken
Called when a unit is transferred between teams.
UnitGiven
Called when a unit is transferred between teams.
UnitIdle
Called when a unit is idle (empty command queue).
UnitCommand
Called after when a unit accepts a command, after AllowCommand returns true.
UnitCmdDone
Called when a unit completes a command.
UnitDamaged
Called when a unit is damaged (after UnitPreDamaged).
UnitStunned
Called when a unit changes its stun status.
UnitExperience
Called when a unit gains experience greater or equal to the minimum limit set by calling Spring.SetExperienceGrade.
UnitHarvestStorageFull
Called when a unit's harvestStorage is full (according to its unitDef's entry).
UnitSeismicPing
Called when a unit emits a seismic ping.
UnitEnteredRadar
Called when a unit enters radar of an allyteam.
UnitEnteredLos
Called when a unit enters LOS of an allyteam.
UnitLeftRadar
Called when a unit leaves radar of an allyteam.
UnitLeftLos
Called when a unit leaves LOS of an allyteam.

Transport

UnitLoaded
Called when a unit is loaded by a transport.
UnitUnloaded
Called when a unit is unloaded by a transport.

Unit Interactions

UnitEnteredUnderwater
UnitEnteredWater
UnitLeftAir
UnitLeftUnderwater
UnitLeftWater
UnitEnteredAir
UnitCloaked
Called when a unit cloaks.
UnitDecloaked
Called when a unit decloaks.
UnitUnitCollision
Called when two units collide.
UnitFeatureCollision
Called when a unit collides with a feature.
UnitMoveFailed
UnitArrivedAtGoal
RenderUnitDestroyed
Called just before a unit is invalid, after it finishes its death animation.

Draw* Functions

DrawGenesis
Use this callin to update textures, shaders, etc.
DrawWorld
Spring draws command queues, 'map stuff', and map marks.
DrawWorldPreUnit
Spring draws units, features, some water types, cloaked units, and the sun.
DrawPreDecals
Called before decals are drawn
DrawWaterPost
DrawShadowPassTransparent
Invoked after semi-transparent shadows pass is about to conclude
DrawWorldShadow
DrawWorldReflection
DrawWorldRefraction
DrawGroundPreForward
Runs at the start of the forward pass when a custom map shader has been assigned via Spring.SetMapShader (convenient for setting uniforms).
DrawGroundPostForward
DrawGroundPreDeferred
Runs at the start of the deferred pass when a custom map shader has been assigned via Spring.SetMapShader (convenient for setting uniforms).
DrawGroundDeferred
DrawGroundPostDeferred
This runs at the end of its respective deferred pass.
DrawUnitsPostDeferred
Runs at the end of the unit deferred pass.
DrawFeaturesPostDeferred
Runs at the end of the feature deferred pass to inform Lua code it should make use of the $modelgbuffer* textures before another pass overwrites them (and to allow proper blending with e.g.
DrawShadowUnitsLua
DrawShadowFeaturesLua
DrawWorldPreParticles
DrawWorldPreParticles is called multiples times per draw frame.
DrawScreen
Also available to LuaMenu.
DrawScreenEffects
DrawScreenPost
Similar to DrawScreenEffects, this can be used to alter the contents of a frame after it has been completely rendered (i.e.
DrawInMinimap
DrawInMinimapBackground
GameProgress
Called every 60 frames, calculating delta between GameFrame and GameProgress.
KeyMapChanged
Called when the keymap changes

Input

mods
Key Modifier Params
KeyPress
Called repeatedly when a key is pressed down.
KeyRelease
Called when the key is released.
TextInput
Called whenever a key press results in text input.
TextEditing
MousePress
Called when a mouse button is pressed.
MouseRelease
Called when a mouse button is released.
MouseMove
Called when the mouse is moved.
MouseWheel
Called when the mouse wheel is moved.
IsAbove
Called every Update.
GetTooltip
Called when Spring.IsAbove returns true.
cmdOpts
Parameters for command options
ActiveCommandChanged
Called when a command is issued.
CommandNotify
Called when a command is issued.
AddConsoleLine
Called when text is entered into the console (e.g.
GroupChanged
Called when a unit is added to or removed from a control group.
WorldTooltip
MapDrawCmd
GameSetup
RecvSkirmishAIMessage

Downloads

DownloadQueued
Called when a Pr-downloader download is queued
DownloadStarted
Called when a Pr-downloader download is started via VFS.DownloadArchive.
DownloadFinished
Called when a Pr-downloader download finishes successfully.
DownloadFailed
Called when a Pr-downloader download fails to complete.
DownloadProgress
Called incrementally during a Pr-downloader download.

Teams


TeamDied(teamID)

Called when a team dies (see `Spring.KillTeam`).

Parameters:

  1. teamID number

TeamChanged(teamID)

Parameters:

  1. teamID number

PlayerChanged(playerID)

Called whenever a player's status changes e.g.

becoming a spectator.

Parameters:

  1. playerID number

PlayerAdded(playerID)

Called whenever a new player joins the game.

Parameters:

  1. playerID number

PlayerRemoved(playerID, reason)

Called whenever a player is removed from the game.

Parameters:

  1. playerID number
  2. reason string

Projectiles


ProjectileCreated(proID, proOwnerID, weaponDefID)

Called when the projectile is created.

Note that weaponDefID is missing if the projectile is spawned as part of a burst, but `Spring.GetProjectileDefID` and `Spring.GetProjectileName` still work in callin scope using proID.

Parameters:

  1. proID number
  2. proOwnerID number
  3. weaponDefID number

ProjectileDestroyed(proID, ownerID, proWeaponDefID)

Called when the projectile is destroyed.

Parameters:

  1. proID number
  2. ownerID number
  3. proWeaponDefID number

Explosion(weaponDefID, px, py, pz, attackerID, projectileID)

Called when an explosion occurs.

Parameters:

  1. weaponDefID number
  2. px number
  3. py number
  4. pz number
  5. attackerID number
  6. projectileID number

Returns:

  1. bool noGfx if then no graphical effects are drawn by the engine for this explosion.

StockpileChanged(unitID, unitDefID, unitTeam, weaponNum, oldCount, newCount)

Called when a units stockpile of weapons increases or decreases.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. weaponNum number
  5. oldCount number
  6. newCount number

RecvLuaMsg(msg, playerID)

Receives messages from unsynced sent via `Spring.SendLuaRulesMsg` or `Spring.SendLuaUIMsg`.

Parameters:

  1. msg string
  2. playerID number

Save(zip)

Called when a chat command '/save' or '/savegame' is received.

Parameters:

  1. zip table a userdatum representing the savegame zip file. See Lua_SaveLoad.

UnsyncedHeightMapUpdate()

Called when the unsynced copy of the height-map is altered.

Returns:

  1. x1
  2. z1
  3. x2
  4. z2

Update(dt)

Called for every draw frame (including when the game is paused) and at least once per sim frame except when catching up.

Parameters:

  1. dt number the time since the last update.

ViewResize(viewSizeX, viewSizeY)

Called whenever the window is resized.

Parameters:

  1. viewSizeX number
  2. viewSizeY number

FontsChanged()

Called whenever fonts are updated.

Signals the game display lists and other caches should be discarded. Gets called before other Update and Draw callins.

SunChanged()

DefaultCommand(type, id)

Used to set the default command when a unit is selected.

First parameter is the type of the object pointed at (either "unit or "feature") and the second is its unitID or featureID respectively.

Parameters:

  1. type string "unit" | "feature"
  2. id integer unitID | featureID

Features


FeatureCreated(featureID, allyTeamID)

Called when a feature is created.

Parameters:

  1. featureID number
  2. allyTeamID number

FeatureDestroyed(featureID, allyTeamID)

Called when a feature is destroyed.

Parameters:

  1. featureID number
  2. allyTeamID number

FeatureDamaged(featureID, featureDefID, featureTeam, damage, weaponDefID, projectileID, attackerID, attackerDefID, attackerTeam)

Called when a feature is damaged.

Parameters:

  1. featureID number
  2. featureDefID number
  3. featureTeam number
  4. damage number
  5. weaponDefID number
  6. projectileID number
  7. attackerID number
  8. attackerDefID number
  9. attackerTeam number

Common


Initialize()

Called when the addon is (re)loaded.

LoadCode()

Called when the game is (re)loaded.

Shutdown()

Called when the addon or the game is shutdown.

Returns:

  1. nil

GotChatMsg(msg, playerID)

Called when a player issues a UI command e.g.

types /foo or /luarules foo.

Parameters:

  1. msg string
  2. playerID number

Load(zipReader)

Called after `GamePreload` and before `GameStart`.

See Lua_SaveLoad.

Parameters:

  1. zipReader table

Game

GamePreload()

Called before the 0 gameframe.

Is not called when a saved game is loaded.

GameStart()

Called upon the start of the game.

Is not called when a saved game is loaded.

GameOver(winningAllyTeams)

Called when the game ends

Parameters:

  1. winningAllyTeams {number,...} list of winning allyTeams, if empty the game result was undecided (like when dropping from an host).

GamePaused(playerID, paused)

Called when the game is paused.

Parameters:

  1. playerID number
  2. paused boolean

GameFrame(frame)

Called for every game simulation frame (30 per second).

Parameters:

  1. frame number Starts at frame 1

GameFramePost(frame)

Called at the end of every game simulation frame

Parameters:

  1. frame number Starts at frame 1

GameID(gameID)

Called once to deliver the gameID

Parameters:

  1. gameID string encoded in hex.

Units

UnitCreated(unitID, unitDefID, unitTeam[, builderID])

Called at the moment the unit is created.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. builderID number (optional)

UnitFinished(unitID, unitDefID, unitTeam)

Called at the moment the unit is completed.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitFromFactory(unitID, unitDefID, unitTeam, factID, factDefID, userOrders)

Called when a factory finishes construction of a unit.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. factID number
  5. factDefID number
  6. userOrders boolean

UnitReverseBuilt(unitID, unitDefID, unitTeam)

Called when a living unit becomes a nanoframe again.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitConstructionDecayed(unitID, unitDefID, unitTeam, timeSinceLastBuild, iterationPeriod, part)

Called when a unit being built starts decaying.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. timeSinceLastBuild number
  5. iterationPeriod number
  6. part number

UnitDestroyed(unitID, unitDefID, unitTeam, attackerID, attackerDefID, attackerTeam, weaponDefID)

Called when a unit is destroyed.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. attackerID number
  5. attackerDefID number
  6. attackerTeam number
  7. weaponDefID number

UnitTaken(unitID, unitDefID, oldTeam, newTeam)

Called when a unit is transferred between teams.

This is called before `UnitGiven` and in that moment unit is still assigned to the oldTeam.

Parameters:

  1. unitID number
  2. unitDefID number
  3. oldTeam number
  4. newTeam number

UnitGiven(unitID, unitDefID, newTeam, oldTeam)

Called when a unit is transferred between teams.

This is called after `UnitTaken` and in that moment unit is assigned to the newTeam.

Parameters:

  1. unitID number
  2. unitDefID number
  3. newTeam number
  4. oldTeam number

UnitIdle(unitID, unitDefID, unitTeam)

Called when a unit is idle (empty command queue).

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitCommand(unitID, unitDefID, unitTeam, cmdID, cmdParams, options, cmdTag)

Called after when a unit accepts a command, after `AllowCommand` returns true.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. cmdID number
  5. cmdParams table
  6. options cmdOpts
  7. cmdTag number

UnitCmdDone(unitID, unitDefID, unitTeam, cmdID, cmdParams, options, cmdTag)

Called when a unit completes a command.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. cmdID number
  5. cmdParams table
  6. options cmdOpts
  7. cmdTag number

UnitDamaged(unitID, unitDefID, unitTeam, damage, paralyzer, weaponDefID, projectileID, attackerID, attackerDefID, attackerTeam)

Called when a unit is damaged (after UnitPreDamaged).

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. damage number
  5. paralyzer number
  6. weaponDefID number
  7. projectileID number
  8. attackerID number
  9. attackerDefID number
  10. attackerTeam number

UnitStunned(unitID, unitDefID, unitTeam, stunned)

Called when a unit changes its stun status.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. stunned boolean

UnitExperience(unitID, unitDefID, unitTeam, experience, oldExperience)

Called when a unit gains experience greater or equal to the minimum limit set by calling `Spring.SetExperienceGrade`.

Should be called more reliably with small values of experience grade.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. experience number
  5. oldExperience number

UnitHarvestStorageFull(unitID, unitDefID, unitTeam)

Called when a unit's harvestStorage is full (according to its unitDef's entry).

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitSeismicPing(x, y, z, strength, allyTeam, unitID, unitDefID)

Called when a unit emits a seismic ping.

See `seismicSignature`.

Parameters:

  1. x number
  2. y number
  3. z number
  4. strength number
  5. allyTeam number
  6. unitID number
  7. unitDefID number

UnitEnteredRadar(unitID, unitTeam, allyTeam, unitDefID)

Called when a unit enters radar of an allyteam.

Also called when a unit enters LOS without any radar coverage.

Parameters:

  1. unitID number
  2. unitTeam number
  3. allyTeam number
  4. unitDefID number

UnitEnteredLos(unitID, unitTeam, allyTeam, unitDefID)

Called when a unit enters LOS of an allyteam.

Its called after the unit is in LOS, so you can query that unit.

Parameters:

  1. unitID number
  2. unitTeam number
  3. allyTeam number who's LOS the unit entered.
  4. unitDefID number

UnitLeftRadar(unitID, unitTeam, allyTeam, unitDefID)

Called when a unit leaves radar of an allyteam.

Also called when a unit leaves LOS without any radar coverage. For widgets, this is called just after a unit leaves radar coverage, so widgets cannot get the position of units that left their radar.

Parameters:

  1. unitID number
  2. unitTeam number
  3. allyTeam number
  4. unitDefID number

UnitLeftLos(unitID, unitTeam, allyTeam, unitDefID)

Called when a unit leaves LOS of an allyteam.

For widgets, this one is called just before the unit leaves los, so you can still get the position of a unit that left los.

Parameters:

  1. unitID number
  2. unitTeam number
  3. allyTeam number
  4. unitDefID number

Transport


UnitLoaded(unitID, unitDefID, unitTeam, transportID, transportTeam)

Called when a unit is loaded by a transport.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. transportID number
  5. transportTeam number

UnitUnloaded(unitID, unitDefID, unitTeam, transportID, transportTeam)

Called when a unit is unloaded by a transport.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number
  4. transportID number
  5. transportTeam number

Unit Interactions


UnitEnteredUnderwater(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitEnteredWater(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitLeftAir(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitLeftUnderwater(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitLeftWater(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitEnteredAir(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitCloaked(unitID, unitDefID, unitTeam)

Called when a unit cloaks.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitDecloaked(unitID, unitDefID, unitTeam)

Called when a unit decloaks.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitUnitCollision(colliderID, collideeID)

Called when two units collide.

Both units must be registered with `Script.SetWatchUnit`.

Parameters:

  1. colliderID number
  2. collideeID number

UnitFeatureCollision(colliderID, collideeID)

Called when a unit collides with a feature.

The unit must be registered with `Script.SetWatchUnit` and the feature registered with `Script.SetWatchFeature`.

Parameters:

  1. colliderID number
  2. collideeID number

UnitMoveFailed(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

UnitArrivedAtGoal(unitID, unitDefID, unitTeam)

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

RenderUnitDestroyed(unitID, unitDefID, unitTeam)

Called just before a unit is invalid, after it finishes its death animation.

Parameters:

  1. unitID number
  2. unitDefID number
  3. unitTeam number

Draw* Functions

Inside the Draw* functions, you can use the Lua OpenGL Api to draw graphics.

Avoid doing heavy calculations inside these callins; ideally, do the calculations elsewhere and use Draw callins only for drawing.

DrawGenesis()

Use this callin to update textures, shaders, etc.

Doesn't render to screen! Also available to LuaMenu.

DrawWorld()

Spring draws command queues, 'map stuff', and map marks.

DrawWorldPreUnit()

Spring draws units, features, some water types, cloaked units, and the sun.

DrawPreDecals()

Called before decals are drawn

DrawWaterPost()

DrawShadowPassTransparent()

Invoked after semi-transparent shadows pass is about to conclude

This callin has depth and color buffer of shadowmap bound via FBO as well as the FFP state to do "semi-transparent" shadows pass (traditionally only used to draw shadows of shadow casting semi-transparent particles). Can be used to draw nice colored shadows.

DrawWorldShadow()

DrawWorldReflection()

DrawWorldRefraction()

DrawGroundPreForward()

Runs at the start of the forward pass when a custom map shader has been assigned via `Spring.SetMapShader` (convenient for setting uniforms).

DrawGroundPostForward()

DrawGroundPreDeferred()

Runs at the start of the deferred pass when a custom map shader has been assigned via `Spring.SetMapShader` (convenient for setting uniforms).

DrawGroundDeferred()

DrawGroundPostDeferred()

This runs at the end of its respective deferred pass.

Allows proper frame compositing (with ground flashes/decals/foliage/etc, which are drawn between it and `DrawWorldPreUnit`) via `gl.CopyToTexture`.

DrawUnitsPostDeferred()

Runs at the end of the unit deferred pass.

Informs Lua code it should make use of the $model_gbuffer_* textures before another pass overwrites them (and to allow proper blending with e.g. cloaked objects which are drawn between these events and DrawWorld via gl.CopyToTexture). N.B. The *PostDeferred events are only sent (and only have a real purpose) if forward drawing is disabled.

DrawFeaturesPostDeferred()

Runs at the end of the feature deferred pass to inform Lua code it should make use of the $model_gbuffer_* textures before another pass overwrites them (and to allow proper blending with e.g.

cloaked objects which are drawn between these events and DrawWorld via gl.CopyToTexture). N.B. The *PostDeferred events are only sent (and only have a real purpose) if forward drawing is disabled.

DrawShadowUnitsLua()

DrawShadowFeaturesLua()

DrawWorldPreParticles(drawAboveWater, drawBelowWater, drawReflection, drawRefraction)

DrawWorldPreParticles is called multiples times per draw frame.

Each call has a different permutation of values for drawAboveWater, drawBelowWater, drawReflection, and drawRefraction.

Parameters:

  1. drawAboveWater boolean
  2. drawBelowWater boolean
  3. drawReflection boolean
  4. drawRefraction boolean

DrawScreen(viewSizeX, viewSizeY)

Also available to LuaMenu.

Parameters:

  1. viewSizeX number
  2. viewSizeY number

DrawScreenEffects(viewSizeX, viewSizeY)

Parameters:

  1. viewSizeX number
  2. viewSizeY number

DrawScreenPost(viewSizeX, viewSizeY)

Similar to DrawScreenEffects, this can be used to alter the contents of a frame after it has been completely rendered (i.e.

World, MiniMap, Menu, UI).

Parameters:

  1. viewSizeX number
  2. viewSizeY number

DrawInMinimap(sx, sy)

Parameters:

  1. sx number relative to the minimap's position and scale.
  2. sy number relative to the minimap's position and scale.

DrawInMinimapBackground(sx, sy)

Parameters:

  1. sx number relative to the minimap's position and scale.
  2. sy number relative to the minimap's position and scale.

GameProgress(serverFrameNum)

Called every 60 frames, calculating delta between `GameFrame` and `GameProgress`.

Can give an ETA about catching up with simulation for mid-game join players.

Parameters:

  1. serverFrameNum integer

KeyMapChanged()

Called when the keymap changes

Can be caused due to a change in language or keyboard

Input

mods

Key Modifier Params

Fields:

  1. right bool Right mouse key pressed
  2. alt bool Alt key pressed
  3. ctrl bool Ctrl key pressed
  4. shift bool Shift key pressed

KeyPress(keyCode, mods, isRepeat, label, utf32char, scanCode, actionList)

Called repeatedly when a key is pressed down.

Return true if you don't want other callins or the engine to also receive this keypress. A list of key codes can be seen at the SDL wiki.

Parameters:

  1. keyCode number
  2. mods mods
  3. isRepeat boolean If you want an action to occur only once check for isRepeat == false.
  4. label boolean the name of the key
  5. utf32char number (deprecated) always 0
  6. scanCode number
  7. actionList table the list of actions for this keypress

Returns:

  1. boolean halt whether to halt the chain for consumers of the keypress

KeyRelease(keyCode, mods, label, utf32char, scanCode, actionList)

Called when the key is released.

Parameters:

  1. keyCode number
  2. mods mods
  3. label boolean the name of the key
  4. utf32char number (deprecated) always 0
  5. scanCode number
  6. actionList table the list of actions for this keyrelease

Returns:

  1. bool

TextInput(utf8char)

Called whenever a key press results in text input.

Parameters:

  1. utf8char string

TextEditing(utf8, start, length)

Parameters:

  1. utf8 string
  2. start number
  3. length number

MousePress(x, y, button)

Called when a mouse button is pressed.

The button parameter supports up to 7 buttons. Must return true for `MouseRelease` and other functions to be called.

Parameters:

  1. x number
  2. y number
  3. button number

Returns:

  1. boolean becomeMouseOwner

MouseRelease(x, y, button)

Called when a mouse button is released.

Please note that in order to have Spring call `Spring.MouseRelease`, you need to have a `Spring.MousePress` call-in in the same addon that returns true.

Parameters:

  1. x number
  2. y number
  3. button number

Returns:

  1. boolean becomeMouseOwner

MouseMove(x, y, dx, dy, button)

Called when the mouse is moved.

Parameters:

  1. x number final x position
  2. y number final y position
  3. dx number distance travelled in x
  4. dy number distance travelled in y
  5. button number

MouseWheel(up, value)

Called when the mouse wheel is moved.

Parameters:

  1. up boolean the direction
  2. value number the amount travelled

IsAbove(x, y)

Called every `Update`.

Must return true for `Mouse*` events and `Spring.GetToolTip` to be called.

Parameters:

  1. x number
  2. y number

Returns:

  1. boolean isAbove

GetTooltip(x, y)

Called when `Spring.IsAbove` returns true.

Parameters:

  1. x number
  2. y number

Returns:

  1. string tooltip

cmdOpts

Parameters for command options

Fields:

  1. coded integer
  2. alt boolean
  3. ctrl boolean
  4. shift boolean
  5. right boolean
  6. meta boolean
  7. internal boolean

ActiveCommandChanged(cmdID, cmdType)

Called when a command is issued.

Parameters:

  1. cmdID nil or number
  2. cmdType nil or number

CommandNotify(cmdID, cmdParams, options)

Called when a command is issued.

Parameters:

  1. cmdID integer
  2. cmdParams table
  3. options cmdOpts

Returns:

  1. boolean Returning true deletes the command and does not send it through the network.

AddConsoleLine(msg, priority)

Called when text is entered into the console (e.g.

`Spring.Echo`).

Parameters:

  1. msg string
  2. priority integer

GroupChanged(groupID)

Called when a unit is added to or removed from a control group.

Parameters:

  1. groupID number

WorldTooltip(ttType, data1[, data2[, data3]])

Parameters:

  1. ttType string "unit" | "feature" | "ground" | "selection"
  2. data1 number unitID | featureID | posX
  3. data2 number posY (optional)
  4. data3 number posZ (optional)

Returns:

  1. string newTooltip

MapDrawCmd(playerID, type, posX, posY, posZ, data4[, pos2Y[, pos2Z]])

Parameters:

  1. playerID number
  2. type string "point" | "line" | "erase"
  3. posX number
  4. posY number
  5. posZ number
  6. data4 string or number point: label, erase: radius, line: pos2X
  7. pos2Y number when type is line (optional)
  8. pos2Z number when type is line (optional)

GameSetup(state, ready, playerStates)

Parameters:

  1. state string
  2. ready boolean
  3. playerStates table

Returns:

  1. bool success
  2. bool newReady

RecvSkirmishAIMessage(aiTeam, dataStr)

Parameters:

  1. aiTeam integer
  2. dataStr string

Downloads

DownloadQueued(id, name, type)

Called when a Pr-downloader download is queued

Parameters:

  1. id number
  2. name string
  3. type string

DownloadStarted(id)

Called when a Pr-downloader download is started via VFS.DownloadArchive.

Parameters:

  1. id number

DownloadFinished(id)

Called when a Pr-downloader download finishes successfully.

Parameters:

  1. id number

DownloadFailed(id, errorID)

Called when a Pr-downloader download fails to complete.

Parameters:

  1. id number
  2. errorID number

DownloadProgress(id, downloaded, total)

Called incrementally during a Pr-downloader download.

Parameters:

  1. id number
  2. downloaded number
  3. total number