Blitzkrieg Guide To Programming Lua Functions: Calvin
Blitzkrieg Guide To Programming Lua Functions: Calvin
BlitzKrieg
Guide to Programming
    Lua functions
       Version 1.6
Guide to programming Lua functions                                                                                                                    V1.6
23/08/2003                                                                                                                                                         2
Guide to programming Lua functions                                                                                                          V1.6
  GetNAPFencesInScriptArea(strScriptAreaName) .............................................................................13
  GetNFencesInScriptArea(strScriptAreaName)..................................................................................14
  GetNMinesInScriptArea(strScriptAreaName) ...................................................................................14
  GetNScriptUnitsInArea(iScriptID, strScriptAreaName) ....................................................................14
  GetNTrenchesInScriptArea(strScriptAreaName) ..............................................................................14
  GetNUnitsInArea(iPlayer, strScriptAreaName).................................................................................14
  GetNUnitsInCircle(iPlayer, X, Y, Radius) ........................................................................................14
  GetNUnitsInParty(iPlayer)................................................................................................................14
  GetNUnitsInPartyUF(iParty) ............................................................................................................14
  GetNUnitsInPlayerUF(iPlayer) .........................................................................................................14
  GetNUnitsInScriptGroup(iScriptID [, iPlayer]) .................................................................................15
  GetNUnitsInSide(iParty)...................................................................................................................15
  GetNUnitsOfType(strUnitType, iPlayer) ..........................................................................................15
  GetObjCoord(iScriptID) ...................................................................................................................15
  GetObjectHPs(iScriptID_Static) .......................................................................................................15
  GetPartyOfUnits(iScriptID) ..............................................................................................................15
  GetScriptAreaParams(strScriptAreaName) .......................................................................................15
  GetSGlobalVar(strGlobalVarName, 0) .............................................................................................15
  GetSquadInfo(iScriptID)...................................................................................................................16
  GetUnitMorale(iScriptID).................................................................................................................16
  GetUnitState(iScriptID) ....................................................................................................................16
  God(iParty, iMode)...........................................................................................................................17
  IsEntrenched(iScriptID)....................................................................................................................17
  IsFollowing(iScriptID)......................................................................................................................17
  IsPlayerPresent(iPlayer)....................................................................................................................17
  IsStandGround(iScriptID).................................................................................................................17
  IsUnitUnderSupply(iScript) ..............................................................................................................17
  IsWarehouseConnected(iScript_StorageID) ......................................................................................17
  KillScript(strScriptFunctionName) ...................................................................................................18
  LandReinforcement(iReinfID) ..........................................................................................................18
  Loose() .............................................................................................................................................18
  ObjectiveChanged(iObjNum, iState).................................................................................................18
  Password(strName)...........................................................................................................................19
  QCmd ou GiveQCommand : QCmd(iAction, iScriptID [,params, ...])...............................................19
  RandomFloat()..................................................................................................................................19
  RandomInt(n) ...................................................................................................................................19
  ReserveAviationForTimes(iParty, iTime) .........................................................................................19
  RunScript(strScriptFunctionName, iPeriodicity [, iNumberOfRepetitions]) ......................................19
  SetCheatDifficultyLevel(n)...............................................................................................................19
  SetDifficultyLevel(n)........................................................................................................................19
  SetFGlobalVar (strGlobalVarName, fVar) ........................................................................................20
  SetGameSpeed(n) .............................................................................................................................20
  SetIGlobalVar(strGlobalVarName, iVar) ..........................................................................................20
  SetSGlobalVar(strGlobalVarName, sVar).........................................................................................20
  ShowActiveScripts().........................................................................................................................20
  Suicide()...........................................................................................................................................20
  SwitchWeather(iState) ......................................................................................................................20
  SwitchWeatherAutomatic(iState)......................................................................................................20
  Trace(strText [, params, …]) ............................................................................................................21
  ViewZone(strScriptAreaName, iParam)............................................................................................21
  Win(iParty).......................................................................................................................................21
23/08/2003                                                                                                                                              3
Guide to programming Lua functions                                                                                                      V1.6
Script example..................................................................................................................................22
23/08/2003                                                                                                                                             4
Guide to programming Lua functions                                                             V1.6
                                                         *
                                                         **
23/08/2003                                                                                             5
Guide to programming Lua functions                                                                    V1.6
AddIronMan(iScriptID)
    •   Forbids AI general to supply unit(s) with iScriptID script group
    •   Linked function : Cmd(23, ...)
ChangeFormation(iScriptID, iFormation)
    •   Order squad units to change formation
    •   Classical squad unit :
• Sniper
ChangePlayer(iScriptID, iParty)
    •   Allow to change the owner of the unit
ChangeWarFog(iParty)
    •   Change the current fog to war to the player iParty
23/08/2003                                                                                                   6
Guide to programming Lua functions                                                                            V1.6
23/08/2003                                                                                                            7
Guide to programming Lua functions                                                                            V1.6
23/08/2003                                                                                                           8
Guide to programming Lua functions                                                                         V1.6
                         o   Declare at less 1 Appear point into the “Map Unit Creation Property” Menu
                         o   Select 1 or more planes in the “Bombers” section
                         o   Execute the function EnableAviation()
    •   Avion_iScriptID is a temporary iScriptID assigned to the planes for the flight. This Avion_IScriptID allows
        to execute the functions : GetObjCoord(), GetUnitState(), etc..
    •   Note : in placing a truck near an artillery gun, the truck will automatically supply this artillery gun
    •   Note : don’t forget to place appropriate trucks regarding artillery gun : Heavy Artillery = Heavy Trucks
23/08/2003                                                                                                         9
Guide to programming Lua functions                                                                         V1.6
23/08/2003                                                                                                         10
Guide to programming Lua functions                                                                     V1.6
DamageObject(iScriptID, fDamage)
    •   Do some damages to the Object/item or unit specified by iScriptID, and for a damage amount equal to
        fDamage
            o If fDamage = 0 then the unit is destroyed (not the static Objects/items)
            o if fDamage = -1 then the static Objects/items (not the units) are repaired
    •   Eg : DamageObject(200, GetObjectHPs(200)); -- the object/Item is entirely destroyed !!!
DeleteReinforcement(iScriptID)
    •   Remove from map every units with the iScriptID script group belonging to the reinforcement group
        iReinfID
    •   Linked function : LandReinforcement()
    •   Attention : iScriptID corresponding to the iScriptID of units belonging to the iReinfID group, it is then
        posssibe to make a part only of the reinforcements disappear !
DisableAviation(iParty, iAviationType)
    •   Forbids to iParty side to call
    •   iAviationType can take the following values :
                                                                                  Corresponding
                       iAviationType                   Air support
                                                                                    Command
                               0                      Scout Plane                  Cmd(21, ...)
                               1                        Fighters                   Cmd(20, ...)
                               2                      Paratroopers                 Cmd(22, ...)
                               3                       Bombers                     Cmd(19, ...)
                               4                  Ground Attack Planes             Cmd(36, ...)
                              -1                       All Types                        all
• Note :If iParty = -1 then all players will be subject to this forbiding
23/08/2003                                                                                                     11
Guide to programming Lua functions                                                                          V1.6
Draw()
    •   In a multi-players game, the Draw() fonction refer to the withdraw of all players ! (no winners)
EnableAviation(iParty, iAviationType)
    •   To authorize to iParty side to call up Air Support from type iAviationType.
    •   iAviationType can take the following values :
                                                                                Corresponding
                   iAviationType                   Air Support
                                                                                  Command
                           0                       Scout Planes                   Cmd(21, ...)
                           1                         Fighters                     Cmd(20, ...)
                           2                       Paratroopers                   Cmd(22, ...)
                           3                         Bombers                      Cmd(19, ...)
                           4                  Ground Attack Planes                Cmd(36, ...)
                          -1                         All Types                        all
• Note :If iParty = -1 then all players will be subject to this authorization !
FlagReinforcement(nParty)
    •   This function is called in a multiplayer game just after a flag has been captured, and regularly until at less
        a flag is still captured by the nParty team.
    •   To use this command insert the following lines in your script :
                        § function FlagReinforcement(nParty)
                        § local num;
                        §          if (nParty == 0) then
                        §                   ….
                        §          end;
                        §          if (nParty == 1) then
                        §                   ….
                        §          end;
                        § end;
    •   Note : this function is useful to send reinforcements
    •   Note : the function RunSCript() is NOT used to start this command!
GetActiveShellType(iScriptID)
    •   Returns current artillery ammo type
            o If GetActiveShellType() returns 0 value then the current Shell Type is the primary shell type
                corresponding to explosive shell
            o If GetActiveShellType() returns 1 value then the current shell type is the secondary shell type
                corresponding to smoke shell
    •   Linked function: GetNAmmo()
23/08/2003                                                                                                          12
Guide to programming Lua functions                                                                    V1.6
GetAviationState(iPlayer)
    •   Returns the last aviation type called by player iPlayer
                              iAviationType          Air Support
                              0                      Scout Planes
                              1                      Fighters
                              2                      Paratroopers
                              3                      Bombers
                              4                      Ground Attack Planes
GetFGlobalVar(strGlobalVarName, 0)
    •   Returns the value of the strGlobalVarName variable
    •   the strGlobalVarName variable contains a decimal value (eg 10,456)
    •   ex : GetFGlobalVar(« temp.total », 0)
    •   Note : the second parameter 0 is mandatory
    •   Linked function : SetFGlobalVar()
GetFrontDir(iScriptID)
    •   Returns the current direction of the iScriptID unit
    •   the returned value is included between 0 and 65535 that corresponds from 0 to 360 degree
    •   the unit does not exist or it is not an mobile unit if the value –1 is returned
    •   ex : angle = GetFrontDir(iScriptID)/65536 * 360 ; -- returns the angle value
GetIGlobalVar(strGlobalVarName,0)
    •   Returns the value of the strGlobalVarName variable
    •   the strGlobalVarName is an integer value
    •   Note : the second parameter 0 is mandatory
    •   Linked function : SetIGlobalVar()
GetMapSize()
    •   Returns the map size in Script points
    •   ex : sizex, sizey = GetMapSize()
    •   Note : to convert into VIS points divide by 64
    •   Note : a map 4x4 means (4*16)x(4*16) in VIS points and (4*16*64)x(4*16*64) in Script points
GetNAmmo(iScriptID)
    •   Returns the ammunition levels (primary and secondary) of the unit iScriptID
    •   ex : primary_ammo, secondary_ammo ) GetAmmo(iScriptID) ;
    •   Note : As a rule, the primary ammo is the armor piercing and the secondary ammo is smoke
GetNAntitankInScriptArea(strScriptAreaName)
    •   Returns the number of antitank mines found in the strScriptAreaName zone
    •   Note : This function does not work !! The value returned is always the 0
GetNAPFencesInScriptArea(strScriptAreaName)
    •   Returns the number of barbed wire found in the strScriptAreaName zone
    •   Note : 1 barbed wire square = 1 vis
    •   Linked function GetNFencesInScriptArea()..
23/08/2003                                                                                                   13
Guide to programming Lua functions                                                                             V1.6
GetNFencesInScriptArea(strScriptAreaName)
    •   Returns the number of barbed wire found in the strScriptAreaName zone
    •   Note : 1 barbed wire square = 1 vis
    •   Note : the result is identical to the GetNAPFencesInScriptArea() function
GetNMinesInScriptArea(strScriptAreaName)
    •   Returns the number of mines found in the strScriptAreaName zone
    •   Note : there is not distinction between antipersonnel and antitank mines
GetNScriptUnitsInArea(iScriptID, strScriptAreaName)
    •   Returns the number of units with the iScriptID value found in the strScriptAreaName zone
    •   Note : an infantry squad of 10 men returns 1 value
GetNTrenchesInScriptArea(strScriptAreaName)
    •   Returns the trench length found in the strScriptAreaName zone
    •   GetUnitState() returns the 9 value, when an infantry squad is in a trench
GetNUnitsInArea(iPlayer, strScriptAreaName)
    •   Returns the number of iPlayer units found in the strScriptAreaName zone
    •   Note : an infantry squad returns the number of men which it a composes
    •   Note : an artillery unit counts for 4 (3 men + the artillery unit)
    •   Note : the units in the buildings are also counted
GetNUnitsInCircle(iPlayer, X, Y, Radius)
    •   Returns the number of iPlayer units found in the circle defined by the x,y coordinates and diameter
        Radius
    •   Note : an infantry squad returns the number of men which it a composes
    •   Note : an artillery unit counts for 4 (3 men + the artillery unit)
    •   Note : the units in the buildings are also counted
GetNUnitsInParty(iPlayer)
    •   Returns the number of iPlayer units in game
    •   Note : an infantry squad returns the number of men which it a composes
    •   Note : an artillery unit counts for 1. If the gunners are killed the artillery unit becomes a neutral unit and it
        counts for 0!
    •   Note : the units in the buildings are also counted
GetNUnitsInPartyUF(iParty)
    •   Returns the number of iParty units in game
    •   This function is for the multiplayer game
    •   Note : the value returned is the sum of the command GetNUnitsInParty() for each player in the team
        iParty.
GetNUnitsInPlayerUF(iPlayer)
    •   Returns the number of iPlayer units
    •   This function is for the multiplayer game
    •   Note : an infantry squad counts for 1
23/08/2003                                                                                                             14
Guide to programming Lua functions                                                                             V1.6
GetNUnitsInScriptGroup(iScriptID [, iPlayer])
    •   Returns the number of units in the iScriptID group
    •   Note : an infantry squad counts for 1
    •   Note : an artillery unit counts for 1. If the gunners are killed the artillery unit becomes a neutral unit and it
        counts for 0!
    •   The iPlayer option allows to know if the artillery unit is operational
    •   ex : the artillery unit with the iScriptID 100 : GetNUnitsInScriptGroup(100, 1) = 1
    •   ex : the gunners are killed : GetNUnitsInScriptGroup(100, 1) = 0
GetNUnitsInSide(iParty)
    •   Returns the number of units in the iParty team
    •   Note : an infantry squad returns the number of men which it a composes
GetNUnitsOfType(strUnitType, iPlayer)
    •   Returns the number of iPlayer units of specific type
    •   strUnitType can have the following values :
                    § sniper
                    § officer
                    § ...
    •   ex : GetNUnitsOfType(« sniper », 1) – returns the number of sniper for player 1.
GetObjCoord(iScriptID)
    •   Returns the coordinates of the iScriptID unit
    •   the coordinates returned are expressed in script points
    •   ex : x, y = GetObjCoord(100)
    •   Note : if x = -1 and/or y = -1 then the unit does not exist
GetObjectHPs(iScriptID_Static)
    •   Returns the hit points of the static unit iScriptID_Static (buildings, etc…)
    •   This function does not work with the mobile units
GetPartyOfUnits(iScriptID)
    •   Returns the team number of the iScriptID unit
GetScriptAreaParams(strScriptAreaName)
    •   Returns the strScriptAreaName zone coordinates
    •   if strScriptAreaName zone is a rectangle, the values returned are the following :
              o x, y, half_length, half_width = GetScriptAreaParams(« Alarme ») ;
    •   if strScriptAreaName zone is a circle, the values returned are the following :
              o x, y, diameter = GetScriptAreaParams(« Alarme ») ;
GetSGlobalVar(strGlobalVarName, 0)
    •   Returns the value of the strGlobalVarName variable
    •   the strGlobalVarName variable contains a string value
    •   Note : the second parameter 0 is mandatatory
    •   Linked function : SetSGlobalVar()
23/08/2003                                                                                                             15
Guide to programming Lua functions                                                                                  V1.6
GetSquadInfo(iScriptID)
    •        Returns the current formation of the iScriptID unit
                                                                                            GetSquadInfo( for a
                                                        GetSquadInfo()
                                                                                                  sniper)
                  Does not exist !                           -2 (-3)                               -2 (-3)
                 Default formation                              0                                     0
                   Forced mach                                  1                                     1
                   Formation ->                          2 – defensive                          2 – furtively
                 Assault formation                              3                                     3
    •        Linked function : ChangeFormation()
GetUnitMorale(iScriptID)
    •        Returns the 1 value for all units other than infantry unit
    •        Note : I am not sure of the useful of this command !
GetUnitState(iScriptID)
    •        Returns the staus of the iScriptID unit.
    •        the value returned is included between –1 and n (see below)
    •        Note : GetUnitState() is a very useful command
                                                        Linked                                                    Linked
                            Comments                                      Value          Comments
   Value                                               command                                                   command
                                                                                  Expectation for gathering
        -1      the unit does not exist                    NA              23
                                                                                  a formation
        0       Unknown status                             NA              24     The unit is fixed on atruck    Cmd(31, ...)
        1       the unit is waiting                        NA              25     Serve a gun
        2       Waits for loading the passenger                            26     Bombardment with a dive
                                                                                  The paratroopers have
        3       The unit is inside a vehicle           Cmd(4, ...)         27                                    Cmd(22, ...)
                                                                                  jumped
        4       It is unloaded from an unit                                28     the dead plane departs
        5       It is loaded into transport                                29     Construction a long object
        6       The unit is going into a building      Cmd(6, ...)         30     the unit repairs the bridge
                                                                                  Engineers search for
        7       The unit is going into a trench                            31
                                                                                  mines
        8       The unit is into a building            Cmd(6, ...)         32     the units is moving            Cmd(0, ...)
        9       The unit is into a trench                                  33     the units is using spy glass
                                                                                  the unit is using a constant
     10         The unit leaves a building                                 34                                    Cmd(16, ...)
                                                                                  fire
     11         The unit is in assault mode            Cmd(3, ...)         35     the unit repairs a building
     12         The unit leaves an entrenchment                            36     the unit repairs a unit        Cmd(24, ...)
                                                                                  the unit is distributing
     13         The unit attacks a static object                           37                                    Cmd(23, ...)
                                                                                  ammunition
     14         To be built in a formation                                 38     the unit is healing unit       Cmd(43, ...)
                                                                                  The unit is constructing a
     15         the unit is an ambush mode            Cmd(14, ...)         39
                                                                                  bridge
                lthe unit is shooting on ranging                                  the unit is constructing
     16                                                Cmd(15, ...)        40
                areas                                                             hedgehog
     17         The unit is in a transport                                 41     the unit is putting mines      Cmd(11, ...)
     18         The unit is constructing a fence                           42     -                                  -
                                                                                  we are
     19         The unit is constructing a trench                          43
                                                                                  developed/unwrapped
     20         -                                            -             44     -
     21         The unit is attacking                                      45     -
                The unit is attacking a unit into a
     22                                                                    46     Compulsory movement
                building
                                                                           47     we go to cling a gun
23/08/2003                                                                                                                 16
Guide to programming Lua functions                                                                             V1.6
God(iParty, iMode)
    •   This function is useful to test a map by affecting a special mode to the units of the iParty player
                                                                                   iMode
                             Stop completely the special mode (all modes)             0
                                                 the units are invulnerable           1
             The units are invulnerable and the opponents are killed at the
                                                                                     2*
                                                                 first contact
                                the opponents are killed at the first contact        3*
                                              stop the invulnerability mode          4
                    stop the opponents are killed at the first contact mode          5*
IsEntrenched(iScriptID)
    •   This function tests if the iScriptID unit is entrenched
    •   if the unit is entrenched the 1 value is returned, else the 0 value is returned.
IsFollowing(iScriptID)
    •   This function tests if the iScriptID unit is following another unit
    •   if the unit is following another unit the 1 value is returned , else 0 if the unit does not follow, and –1 if the
        does not exist
    •   Linked function : Cmd(39, …)
IsPlayerPresent(iPlayer)
    •   This function tests if the iPlayer player is still in game (in multiplayer game).
    •   if the player is still in game the 1 value is returned, else the 0 value is returned
IsStandGround(iScriptID)
    •   This function tests if the iScriptID unit is “stand ground” (key [E]).
    •   if the unit is « stand ground » the 1 value is returned, else the 0 value is returned.
IsUnitUnderSupply(iScript)
    •   Returns always the 1 value… ??!!
IsWarehouseConnected(iScript_StorageID)
    •   this function tests if a campaign supply depot is connected to a main
        supply depot.
    •   the 1 value is returned when a campaign suplly depot is connected, else
        the 0 value is returned.
23/08/2003                                                                                                             17
Guide to programming Lua functions                                                                            V1.6
KillScript(strScriptFunctionName)
    •   This function stops/kills the execution of the strScriptFunctionName function which was at least called
        once.
    •   Note : the interest of this function is to change the frequence of a function executed by the RunScript()
        function. Ex. At the beginning of the game the function A() is executed each second : RunScript(« A »,
        1000) ;. During the game, an event made that the frequence must be changed. So the function A() is
        stopped by the KillScript() function, then restarted each 5 seconds with the function RunScript() :
        RunScript(“A”, 5000).
LandReinforcement(iReinfID)
    •   This function calls the iReinfID reinforcement on the map.
    •   How define reinforcement from the map editor :
            o Put the units on the map which will compose the reinforcement
            • Assign the same iScriptID for each unit in the group/the reinforcement
            • Create from the « reinforcement group » menu a new reinforcement group and assign a number
                to this reinforcement group : “Group ID” (it’s the future iReinfID)
            • Select the check box “Group N : xxx”, where xxx is the groupID or iReinfID; then add a unit group
                with the iScriptID : use the “Add group with iScriptID” button.
Loose()
    •   In solo game, this function causes the defeat of the human player.
ObjectiveChanged(iObjNum, iState)
    •   this function displays the iObjNum objective. The description of the objective is contained in the both files
        <iObjNum>.txt & <iObjNum>h.txt in the same directory of “1.xml” file.
    •   Ex. ObjectiveChanged(0,0) ; -- displays the contents of the 0.txt file with title the contents of the 0h.txt file
    •   Note : the files have to be saved in UNICODE format. Use the NotePad tool and in the sub menu “Save
        as” select the unicode format.
    •   the iState parameter refers to the objective state .
                   iState                                      Objective
                      0         the objective is displayed (description and an arrow on the minimap)
                      1                     the objective is reached, the arrow disappears
                      2                                       Never tested !
23/08/2003                                                                                                            18
Guide to programming Lua functions                                                                      V1.6
Password(strName)
    •   This function allows to use special functions like God() function.
    •   Note : the only know parameter is « Panzerklein »
RandomFloat()
    •   The RandomFloat() function returns a random value (a decimal value) between 0 and 1.00
RandomInt(n)
    •   The RandomInt() funtion returns a random value (an interger value) between 0 and n-1
ReserveAviationForTimes(iParty, iTime)
    •   This function seems to forbid all aviation for the iParty team and during iTime millisenconds
SetCheatDifficultyLevel(n)
    •   Set the cheat level of the game
    •   the N value can be 0, 1 or 2
    •   Note : I did not know the impact of each cheat level!
SetDifficultyLevel(n)
    •   Set the difficulty level of the game
    •   the N value can be 0 (easy) , 1 (Normal) or 2 (Hard)
23/08/2003                                                                                                       19
Guide to programming Lua functions                                                                            V1.6
SetGameSpeed(n)
    •   Set the game speed
    •   the N value can be from 0 to 19
    •   Note : The 0 value seems to be the normal speed.
SetIGlobalVar(strGlobalVarName, iVar)
    •   Assign the iVar value (an integer value) to the strGlobalVarName global variable
    •   Note : if the strGlobalVarName global variable does not exist, the first allocation will create it.
    •   Linked function : GetIGlobalVar()
SetSGlobalVar(strGlobalVarName, sVar)
    •   Assign the sVar value (a string characters) to the strGlobalVarName global variable
    •   Note : if the strGlobalVarName global variable does not exist, the first allocation will create it.
    •   Linked function : GetSGlobalVar()
ShowActiveScripts()
    •   In Console mode during a game, the ShowActiveScripts() function shows the current functions executed
        by the RunScript() function.
Suicide()
    •   The Suicide() function causes the end of the current function. The function will be NOT re-executed.
    •   Ex : the following Essai() function is executed each second in order to test a global variable. If the global
        variable is true, a message is displayed and it will be not necessary to reexecute the function (the
        Suicide() function), else the Essai() function will be reexecuted.
        Essai()
                if (GetIGlobalVar(« gTest », 0) == 1) then
                         DisplayTrace(“test ok”);
                         Suicide(); -- Means that the Essai() function will be not reexecuted
                end ;
        end ;
SwitchWeather(iState)
    •   Switch the weather, if iState is 1, the weather becomes BAD and the aviation is not available.
    •   if iState is 0, the weather becomes GOOD, and the aviation is available
SwitchWeatherAutomatic(iState)
    •   Set the random weather.
    •   if iState is 1, the weather is random.
    •   if iState is 0, the weather is ALWAYS the same.
23/08/2003                                                                                                           20
Guide to programming Lua functions                                                                     V1.6
ViewZone(strScriptAreaName, iParam)
    •   Allow to see the strScriptAreaName zone without fog, if iParam is 1
    •   if iParam is 0, the strScriptAreaName zone is visible with fog
Win(iParty)
    •   In solo game, the iParty player WINS
    •   in mutiplayer game , the iParty team WINS
                                                      *
                                                      **
Pz.Kpfw II.Ausf C
23/08/2003                                                                                                     21
Guide to programming Lua functions                                                                            V1.6
Script example
The following script is called Support. It’s an generic script, this script is not linked to the map by Zone area for
objectives, etc… The purpose of this script is when an IA unit is attacked, the unit send out an alarm and the
nearest units available come to support/help it!
--
-- Support.lua V1.2
-- Calvin -    29/05/03
--             16/06/03 - Ajout du test des tranchées
--                      - Ajout d'une zone max d'intervention
--
-- THE PURPOSE OF THIS SCRIPT IS TO SEND OUT AN ALARM WHEN AN UNIT IS ATTACKED
-- IN ORDER TO HAVE HELP/SUPPORT FROM THE NEAREST UNIT(S)!
--
-- PRE REQUISITES
-- Affecting an iScriptID for each unit OR GROUP of units!
-- The infantry (inside or outside building) must have an iScriptID between 101 (min) and 110 (max)
-- The tanks or Armored vehicles must have an iScriptID between 201 (min) and 210 (max)
-- The Guns must have an iScriptID 301 (min) and 310 (max)
-- The trucks must have an iScriptID 401 (min) and 410 (max)
-- The special units must have an iScriptID 501 (min) and 510 (max)
--
-- The script manages 50 units as maximum with an iScriptID between 100 and 510
-- the units with an iScriptID below 100 and above 510 are managed as usual by BK or by other functions
in the script!
-- and for many reasons, it's not mandatory to affect an iScriptID for all units!
--
-------------------------
-- CONSTANTES
-- Constantes - x = GetUnitState(iScriptID)
ETAT_NEXISTEPAS               = -1
ETAT_INDISPONIBLE     = 0
ETAT_ENATTENTE        = 1
ETAT_ENDEFENSE            = 8
ETAT_DSTRANCHEE                   = 9
ETAT_MVT_ASSAUT                   = 11
23/08/2003                                                                                                              22
Guide to programming Lua functions                                                                    V1.6
ETAT_ATTAQUE_1         =   13
ETAT_EMBUSCADE         =   15
ETAT_TIR_X             =   16
ETAT_POSE_BARBELES     =   18
ETAT_ATTAQUE_2         =   21
ETAT_MVT_NORMAL                    = 32
ETAT_JUMELLES          =   33
ETAT_TIR_W             =   34
ETAT_REPARER           =   36
ETAT_RECHARGER         =   37
ETAT_PIVOTE            =   43
ETAT_REMORQUE          =   47
--- =================================================================
-- gActiveUnits[][1] = iDScript
-- gActiveUnits[][2] = Status
-- gActiveUnits[][3] = 1 (attack mode) ou 0 (defense mode)
gActiveUnits = {{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},
 {0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},
 {0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},
 {0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},
 {0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0}}
MAX_ACTIVE_UNITS = 50
UNIT_DEF                = 0      -- [][3]
UNIT_ATT                = 1      -- [][3]
-- Unit Types
UTYPE_INF              =   100
UTYPE_TANK             =   200
UTYPE_GUN              =   300
UTYPE_TRUCK            =   400
UTYPE_SPECIAL          =   500
UTYPE_INF_ID           =   1
UTYPE_TANK_ID          =   2
UTYPE_GUN_ID           =   3
UTYPE_TRUCK_ID         =   4
UTYPE_SPECIAL_ID       =   5
UTYPE_UNITS_MAX = 10
-- The gActiveTypeUnits array contains for each unit type the number of units
gActiveTypeUnits = {0, 0, 0, 0, 0}
-- ========================================================================================
-- Function GetHowManyUnits()
-- the purpose of the function GetHowManyUnits() is to return the number of units for the unit type given
in parameter
--
-- Note : the max number of units in the gActiveUnits[][]array is MAX_ACTIVE_UNITS (50 units!!)
-- Input parameters :
-- arg[1]      the iScriptID to test
-- Output parameters :
--
-- Calling protocol :
-- GetHowManyUnits(iScriptID)
--
function GetHowManyUnits(...)
local i = 1;
local n = 0;
while (i<UTYPE_UNITS_MAX) do
        if (GetNUnitsInScriptGroup(arg[1]+i, PLAYER_ID) > 0) then
                n = n +1;
        end;
        i = i + 1;
       end;
return n;
23/08/2003                                                                                                      23
Guide to programming Lua functions                                                                V1.6
end;
-- ========================================================================================
-- Function InitActiveUnits()
-- the purpose of the function InitActiveUnits() is to fill the gActiveUnits[][]array
-- the gActiveUnits[][]array is filling as following :
--
-- first get the number of unit for each unit type on the map.
-- there are 5 unit types : Infantery, Tank, Gun, Truck and special unit (sniper)
-- the max of unit for each unit type is UTYPE_UNITS_MAX (10 units of the same type)
-- the function GetHowManyUnits() returns the number of units on map
--
-- then the state of each unit is tested (GetUnitState())
-- By default the Guns, Trucks and special units are in defense mode.
-- it means they cannot help a unit sending out an alarm
-- The infantery in building or entranched are considered in defense mode also.
--
-- Note : the max number of units in the gActiveUnits[][]array is MAX_ACTIVE_UNITS (50 units!!)
-- Input parameters :
-- None
-- Output parameters :
-- None
-- Calling protocol :
-- InitActiveUnits()
--
function InitActiveUnits()
local n, i, j, u = 0, 0, 0, 0;
-- Initialisation de gActiveTypeUnits[]
gActiveTypeUnits[UTYPE_INF_ID]               = GetHowManyUnits(UTYPE_INF);
gActiveTypeUnits[UTYPE_TANK_ID]              = GetHowManyUnits(UTYPE_TANK);
gActiveTypeUnits[UTYPE_GUN_ID]               = GetHowManyUnits(UTYPE_GUN);
gActiveTypeUnits[UTYPE_TRUCK_ID]     = GetHowManyUnits(UTYPE_TRUCK);
gActiveTypeUnits[UTYPE_SPECIAL_ID]   = GetHowManyUnits(UTYPE_SPECIAL);
i = 0;
while (i<n) do
        Trace(" i %g id %g status %g D/A %g", i+1, gActiveUnits[i+1][1], gActiveUnits[i+1][2],
gActiveUnits[i+1][3]);
        i = i +1;
end;
23/08/2003                                                                                                24
Guide to programming Lua functions                                                                V1.6
Suicide();
end;
-- ========================================================================================
-- Function Test_Att()
-- the purpose of the function Test_Att() is to determided if an unit is under an attack!
-- the tested units are only the referenced units in the gActiveUnits[][]array.
--
-- An infantery squad is under attack when opponents enter in a zone of ALARME_RAYON around the infantery
squad
-- The Tank and Gun units are under attack if the function GetUnitState() returns 21
-- A truck is under attack when opponents enter in a zone of ALARME_RAYON around the truck
-- A sniper is under attack when opponents enter in a zone of (ALARME_RAYON+(2*64)) around the sniper
--
-- When an unit is under attack, the SelectUnitToHelp() function is called to find the nearest unit to
help the attacked unit!
-- Input parameters :
-- None
-- Output parameters :
-- None
-- Calling protocol :
-- Test_Att();
--
function Test_Att()
local i = 0;
local uid = 0;
local x,y = 0,0;
if (GetIGlobalVar("temp.map.EC",0) == 0) then
        SetIGlobalVar("temp.map.EC",1); -- semaphore
        while (i<GetIGlobalVar("temp.map.nbunits",0)) do
                uid = gActiveUnits[i+1][1];
--              Trace("uid = %g",uid);
                if (GetUnitState(uid) ~= -1) then
                        x,y = GetObjCoord(uid);
                        if (uid < UTYPE_TANK) then    -- test the infantery squad
--                             Trace("UNits in circle %g %g", GetNUnitsInCircle(0,x,y,ALARME_RAYON),
uid);
                                if (GetNUnitsInCircle(0,x,y,ALARME_RAYON) > 0) then
                                       if (gActiveUnits[i+1][2] ~= UNIT_ALARME) then
                                               Trace("Alarme INF %g", uid);
                                               gActiveUnits[i+1][2] = UNIT_ALARME;
                                               SelectUnitToHelp(x,y,uid);
                                       end; -- if UNIT_NORMAL
                                else
                                       if (GetUnitState(uid) == ETAT_ENATTENTE) then
                                               gActiveUnits[i+1][2] = UNIT_NORMAL;
                                       end;
                                end;
                        end; -- If INF
                        if ((uid > UTYPE_TANK) and (uid < UTYPE_GUN)) then -- Test the Tank units
                                if (GetUnitState(uid) == ETAT_ATTAQUE_2) then
                                       if (gActiveUnits[i+1][2] ~= UNIT_ALARME) then
                                               Trace("Alarme Tank %g", uid);
                                               gActiveUnits[i+1][2] = UNIT_ALARME;
                                               SelectUnitToHelp(x,y,uid);
                                       end; -- if UNIT_NORMAL
                                else
                                       if (GetUnitState(uid) == ETAT_ENATTENTE) then
                                               gActiveUnits[i+1][2] = UNIT_NORMAL;
                                       end;
                                end;
                        end; -- If TANK
                        if ((uid > UTYPE_GUN) and (uid < UTYPE_TRUCK)) then -- Test the Gun units
                                if (GetUnitState(uid) == ETAT_ATTAQUE_2) then
                                       if (gActiveUnits[i+1][2] ~= UNIT_ALARME) then
                                               Trace("Alarme Gun %g", uid);
                                               gActiveUnits[i+1][2] = UNIT_ALARME;
                                               SelectUnitToHelp(x,y,uid);
                                       end; -- if UNIT_NORMAL
                                else
                                       if (GetUnitState(uid) == ETAT_ENATTENTE) then
                                               gActiveUnits[i+1][2] = UNIT_NORMAL;
                                       end;
                                end;
                        end; -- If GUN
                        if ((uid > UTYPE_TRUCK) and (uid < UTYPE_SPECIAL))then     -- Test the truck units
                                if (GetNUnitsInCircle(0,x,y,ALARME_RAYON) > 0) then
                                       if (gActiveUnits[i+1][2] ~= UNIT_ALARME) then
                                               Trace("Alarme Truck %g", uid);
23/08/2003                                                                                               25
Guide to programming Lua functions                                                                 V1.6
                                               gActiveUnits[i+1][2] = UNIT_ALARME;
                                               SelectUnitToHelp(x,y,uid);
                                       end; -- if UNIT_NORMAL
                                else
                                       if (GetUnitState(uid) == ETAT_ENATTENTE) then
                                               gActiveUnits[i+1][2] = UNIT_NORMAL;
                                       end;
                                end;
                        end; -- if Truck
                        if ((uid > UTYPE_SPECIAL) and (uid < UTYPE_SPECIAL + 99))then    -- Test the
special untis
                               if (GetNUnitsInCircle(0,x,y,ALARME_RAYON+(2*64)) > 0) then
                                       if (gActiveUnits[i+1][2] ~= UNIT_ALARME) then
                                               Trace("Alarme Unités SpecialesTruck %g", uid);
                                               gActiveUnits[i+1][2] = UNIT_ALARME;
                                               SelectUnitToHelp(x,y,uid);
                                       end; -- if UNIT_NORMAL
                               else
                                       if (GetUnitState(uid) == ETAT_ENATTENTE) then
                                               gActiveUnits[i+1][2] = UNIT_NORMAL;
                                       end;
                               end;
                       end; -- if UNITES SPECIALES
                end; -- if State == -1
                i = i +1;
        end; -- while i
        SetIGlobalVar("temp.map.EC",0);
end; -- if
end;
-- ========================================================================================
-- Function SelectUnitToHelp(...)
-- Activate the nearest unit of the unit sending out an alarm
--
-- Input parameters :
-- arg[1]      x coordinate of unit sending out an alarm
-- arg[2]      y coordinate of unit sending out an alarm
-- arg[3]      uid of the sending out an alarm
-- Output parameters :
-- None
-- Calling protocol :
-- SelectUnitToHelp(x,y,uid);
--
function SelectUnitToHelp(...)
local i, distance, tp, uid, uidx = 0,0,0,0,0;
local x,y = 0,0;
-- loop to check all available units
-- the public variable "temp.map.nbunits" contains the number of referenced units in the array
gActiveUnits[][]
while (i<GetIGlobalVar("temp.map.nbunits",0)) do
        -- test if the eligible unit is waiting and if it can attack/help
        if ((gActiveUnits[i+1][2] == UNIT_NORMAL) and (gActiveUnits[i+1][3] == UNIT_ATT)) then
        -- test if the eligible unit is still existing.
                if (GetUnitState(gActiveUnits[i+1][1]) ~= -1) then
                       -- Get the coordinate of the eligible unit
                       x,y = GetObjCoord(gActiveUnits[i+1][1]);
                       -- Calculate the distance between the eligible unit and the unit sending out an
alarm
                       tp = CalculDistance(arg[1]/64, arg[2]/64, x/64,y/64);
                       -- Test if the calculated distance is included in the intervention area
                       if (tp < ZONE_MAX_INTERVENTION) then
                               -- Compare with the previous and save the shortest calculated distance
                               if ((distance == 0) or (tp < distance)) then
                                      distance = tp;
                                      uid = gActiveUnits[i+1][1];
                                      uidx = i+1;
                               end; -- end if distance
                       end; -- end if max_zone_intervention
                end; -- end Getunitstate
        end; -- end if
        i = i +1;
end; -- end while
-- if the distance variable is > 0 then the nearest unit has been found, the uid variable contains the
iScriptID of the unit
-- else there are no more units available
if (distance > 0) then
        gActiveUnits[uidx][2] = UNIT_MVT;
        if (uid < UTYPE_TANK) then
                -- if the unit is an infantery squad, give the order to the unit to move to the location
23/08/2003                                                                                                 26
Guide to programming Lua functions                                                                   V1.6
                -- Note : it's important to separate the infantery squad from all other unit types
                -- because if you give the order 3, the officer will not follow the squad....
                Cmd(0,uid,arg[1],arg[2]);
        else
                -- give the order to the unit to move in assault mode to the location
                Cmd(3,uid,arg[1],arg[2]);
        end;
        Trace("Unite en appui = %g soutient l'unité %g", uid, arg[3]);
end;
end;
-- ========================================================================================
-- Function CalculDistance(...)
-- Calculate the distance between two points A & B on the map
-- following the mathematical expression : distance = SQRT((Bx-Ax)² + (By-Ay)²)
-- the coordinates can be given in VIS points or SCRIPT points
-- Note : 1x1 VIS square is equal to 64x64 SCRIPT points
-- Input parameters :
-- the coordinates of point A and point B
-- arg[1]      x coordinate A
-- arg[2]      y coordinate A
-- arg[3]      x coordinate B
-- arg[4]      y coordinate B
-- Output parameters :
-- returns the distance between the points A & B
-- Calling protocol :
-- CalculDistance(Ax, Ay, Bx, By);
--
function CalculDistance(...)
return sqrt(((arg[3]-arg[1])*(arg[3]-arg[1])) + ((arg[4]-arg[2])*(arg[4]-arg[2])));
end;
-- ========================================================================================
-- Function sqrt()
-- Calculate the square of the x value
-- from the official map Secure_area.lua
--
-- Input parameters :
-- x   integer value
-- Output parameters :
-- returns the square of x
-- Calling protocol :
-- sqrt(x);
--
function sqrt( x)
local ITNUM = 4;
local sp = 0
local i = ITNUM;
local inv = 0;
local a, b;
        if ( x <= 0) then return 0; end;
        if ( x < 1) then
                x = 1 / x;
                inv = 1;
        end;
        a = 2;
-- Newtonian algorithm
        while (i > 0) do
                b = x / a;
                a = a + b;
                a = a * 0.5;
                i = i - 1;
        end;
--
        while ( sp > 0) do
                sp = sp - 1;
                a = a * 4;
        end;
        if ( inv == 1) then
                a = 1 / a;
        end;
23/08/2003                                                                                                  27
Guide to programming Lua functions                                                               V1.6
        return a;
end;
--------------------------------------------------------------------------------------------------
function Init()
        Trace("Deb Init");
--     Start the InitActiveUnits function
        RunScript("InitActiveUnits",1000);
----------------
        Password( "Panzerklein" )
        ChangeWarFog(1)
        God(1,1)
-----------------
        RunScript("Test_Att", 2000);
        Trace("Fin Init");
end;
23/08/2003 28