This section describes global variables (or 'globals' for short) that are available from all scripts. You typically cannot write to these variables, they are read-only.
derrickPositions
A set of derrick starting positions on the current map. Each item in the set is an object containing the x and y variables for a derrick.startPositions
An array of player start positions on the current map. Each item in the array is an object containing the x and y variables for a player start position.version
Current version of the game, set in major.minor format.selectedPlayer
The player controlled by the client on which the script runs.gameTime
The current game time. Updated before every invokation of a script.modList
An array of the current loaded mods (mod names).difficulty
The currently set campaign difficulty, or the current AI's difficulty setting. It will be one ofSUPEREASY
(campaign only),EASY
,MEDIUM
,HARD
orINSANE
.mapName
The name of the current map.tilesetType
The area name of the map.baseType
The type of base that the game starts with. It will be one ofCAMP_CLEAN
,CAMP_BASE
orCAMP_WALLS
.alliancesType
The type of alliances permitted in this game. It will be one ofNO_ALLIANCES
,ALLIANCES
,ALLIANCES_UNSHARED
orALLIANCES_TEAMS
.powerType
The power level set for this game.maxPlayers
The number of active players in this game.scavengers
Whether or not scavengers are activated in this game, and, if so, which type.mapWidth
Width of map in tiles.mapHeight
Height of map in tiles.scavengerPlayer
Index of scavenger player. (3.2+ only)isMultiplayer
If the current game is a online multiplayer game or not. (3.2+ only)challenge
If the current game is a challenge. (4.1.4+ only)idleTime
The amount of game time without active play before a player should be considered "inactive". (0 = disable activity alerts / AFK check) (4.2.0+ only)gameTimeLimit
The game time limit (match will automatically end if it reaches this duration). (0 = disable limit) (4.4.0+ only)playerLeaveMode
The mode used to handle human players leaving a multiplayer game in progress. (0 = destroy resources, 1 = split resources with team) (4.4.0+ only)tweakOptions
The tweakOptions offered by the current mod / mode, as configured by the user. (4.5.0+ only)groupSizes
A sparse array of group sizes. If a group has never been used, the entry in this array will be undefined.me
The player the script is currently running as.scriptName
Base name of the script that is running.scriptPath
Base path of the script that is running.Upgrades
A special array containing per-player rules information for game entity types, which can be written to in order to implement upgrades and other dynamic rules changes. Each item in the array contains a subset of the sparse array of rules information in theStats
global. These values are defined:Body
Droid bodiesSensor
Sensor turretsPropulsion
PropulsionsECM
ECM (Electronic Counter-Measure) turretsRepair
Repair turrets (not used, incidentally, for repair centers)Construct
Constructor turrets (eg for trucks)Brain
Brains BaseCommandLimit: How many droids a commander can command. CommandLimitByLevel: How many extra droids a commander can command for each of its rank levels. RankThresholds: An array describing how many kills are required for this brain to level up to the next rank. To alter this from scripts, you must set the entire array at once. Setting each item in the array will not work at the moment.Weapon
Weapon turretsBuilding
Buildings
Stats
A sparse, read-only array containing rules information for game entity types. (For now only the highest level member attributes are documented here. Use the 'jsdebug' cheat to see them all.) These values are defined:Body
Droid bodiesSensor
Sensor turretsECM
ECM (Electronic Counter-Measure) turretsPropulsion
PropulsionsRepair
Repair turrets (not used, incidentally, for repair centers)Construct
Constructor turrets (eg for trucks)Brain
BrainsWeapon
Weapon turretsWeaponClass
Defined weapon classesBuilding
Buildings
playerData
An array of information about the players in a game. Each item in the array is an object containing the following variables:difficulty
(seedifficulty
global constant)colour
number describing the colour of the playerposition
number describing the position of the player in the game's setup screenisAI
whether the player is an AI (3.2+ only)isHuman
whether the player is human (3.2+ only)name
the name of the player (3.2+ only)team
the number of the team the player is part of
MapTiles
A two-dimensional array of static information about the map tiles in a game. Each item in MapTiles[y][x] is an object containing the following variables:terrainType
(seeterrainType(x, y)
function)height
the height at the top left of the tilehoverContinent
(For hover type propulsions)limitedContinent
(For land or sea limited propulsion types)