From Bohemia Interactive Community
					 
					
					
					
					
Hover & click on the images for description
 
Description
- Description:
- Execute scripted FSM and return the FSM handle or 0 when failed. The FSM file is first searched in the mission folder, then in the campaign scripts folder and finally in the global scripts folder. Argument (if any) are available in _this variable inside FSM. Variables set inside FSMs can be read/modified externally, using setFSMVariable and getFSMVariable commands.
 
 The return value is the FSM handle; it can be used to determine (via completedFSM) when the FSM has finished.In Arma 3, the FSM handle is also available within the FSM through the _thisFSM variable. 
 Scripted FSMs are added into the scheduler just like exec scripts, execVM scripts and spawn scripts.
 To see what FSMs are currently in the scheduler, use diag_activeMissionFSMs command.
 ⚠ While the code placed into any of the sections of FSM cannot be suspended ( canSuspend is false), the FSM itself is suspended every simulation between the state's  init and  precondition (exception is the  init state). This is the only place where scripted FSM is suspended/resumed.
The usual difference between the state's  init and  precondition is 1 frame but if the scheduler is busy it can take longer. See  FSM for more information about FSM's structure. 
- Groups:
- Program Flow
Syntax 1
- Syntax:
- arguments execFSM fsmFilePath
- Parameters:
- arguments: Anything - arguments accessible as _this in the FSM
- fsmFilePath: String - file with FSM code
- Return Value:
- Number - FSM handle (also available as _thisFSM in the FSM)
- Syntax:
- execFSM fsmFilePath
- Parameters:
- fsmFilePath: String - file with FSM code
- Return Value:
- Number - FSM handle (also available as _thisFSM in the FSM)
- Syntax:
- arguments execFSM [fsmFilePath, allowTermination]
- Parameters:
- arguments: Anything - arguments accessible as _this in the FSM
- fsmFilePath: String - file with FSM code
- allowTermination (Optional): Boolean - true to allow FSM termination with terminate command. Default false
- Return Value:
- Number - FSM handle (also available as _thisFSM in the FSM)
- Syntax:
- execFSM [fsmFilePath, allowTermination]
- Parameters:
- fsmFilePath: String - file with FSM code
- allowTermination (Optional): Boolean - true to allow FSM termination with terminate command. Default false
- Return Value:
- Number - FSM handle (also available as _thisFSM in the FSM)
Examples
- Example 1:
- Example 2:
- Example 3:
Additional Information
- See also:
- FSM FSM Editor Manual execVM call spawn exec commandFSM completedFSM doFSM getFSMVariable setFSMVariable
Notes
- 
Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
 Only post proven facts here!
Add Note