Startup Parameters – Arma Reforger

From Bohemia Interactive Community
m (Fix GVI usage)
(Add 1.0.0's autodeployFaction and autodeployLoadout)
 
(48 intermediate revisions by 6 users not shown)
Line 1: Line 1:
{{TOC|side}}
{{TOC|side}}
{{Feature|informative|Startup parameters' ''names'' are case-insensitive - e.g {{hl|-logstats}} and {{hl|-LogSTATS}} are identical.}}
Startup parameters are command line interface(CLI) arguments that go after the executable's name in order to set options; e.g {{hl|ArmaReforgerSteam.exe -window}} to start the game in {{Link|#window}}ed mode.
{{Feature|informative|
* Startup parameters' ''names'' are case-insensitive - e.g {{hl|-logstats}} and {{hl|-LogSTATS}} are identical.
* Spaces in parameter values must be wrapped in quotations - e.g. {{hl|-addonDownloadDir "E:\Arma Addons"}}
}}
{{TOC|subtoc
{{TOC|subtoc
|content=
|content=
* 1. {{Link|#General}}
{{Columns|2|
* 2. {{Link|#Window}}
# {{Link|#General}}
* 3. {{Link|#Workbench}}
# {{Link|#Window}}
* 4. {{Link|#Workbench - LocalizationEditor Module}}
# {{Link|#Workbench}}
* 5. {{Link|#Workbench - NavmeshGeneratorMain Module}}
# {{Link|#Workbench - AnimationEditor Module}}
* 6. {{Link|#Workbench - ScriptEditor Module}}
# {{Link|#Workbench - LocalizationEditor Module}}
* 7. {{Link|#Workbench - WorldEditor Module}}
# {{Link|#Workbench - NavmeshGeneratorMain Module}}
* 8. {{Link|#Hosting}}
# {{Link|#Workbench - ResourceManager Module}}
* 9. {{Link|#Network Tuning}}
# {{Link|#Workbench - ScriptEditor Module}}
* 10. {{Link|#Debug}}
# {{Link|#Workbench - WorldEditor Module}}
* 11. {{Link|#Profiling}}
# {{Link|#Hosting}}
# {{Link|#Network Tuning}}
# {{Link|#Debug}}
# {{Link|#Profiling}}
}}
}}
}}


Line 49: Line 57:


{{hl|-addonDownloadDir}} specifies where the game and the Workshop should download addons. Downloaded addons will be stored in addons subfolder inside of target directory.
{{hl|-addonDownloadDir}} specifies where the game and the Workshop should download addons. Downloaded addons will be stored in addons subfolder inside of target directory.
{{Feature|important|It is recommended to use ''absolute'' paths to Mod directories even though the provided path ''can'' be relative to the executable location.}}{{Feature|informative|It is not necessary to combine this command with '''addonsDir''' parameter}}
{{Feature|important|It is recommended to use ''absolute'' paths to Mod directories even though the provided path ''can'' be relative to the executable location.}}{{Feature|informative|It is not necessary to combine this command with '''addonsDir''' parameter.}}


; Example
; Example
  ArmaReforgerSteam.exe -addonDownloadDir D:\DownloadedMods
  ArmaReforgerSteam.exe -addonDownloadDir D:\DownloadedMods


{{ArgTitle|3|addonTempDir|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|addonTempDir|{{GVI|armaR|1.1.0}}}}


{{hl|-addonTempDir}} specifies the directory for temporary content.
{{hl|-addonTempDir}} specifies the directory for temporary content. The default temporary directory is:
* before {{GVI|armaR|1.4.0}}: {{hl|%localappdata%/Temp/<addon>/<temp data>}} on Windows or {{hl|/tmp/<addon>/<temp data>}} on Linux
* since {{GVI|armaR|1.4.0}}: {{hl|<addonsDir>/<addon>/temp/<temp data>}}


; Example
; Example
  ArmaReforgerSteam.exe -addonTempDir "C:\Temp"
  ArmaReforgerSteam.exe -addonTempDir "C:\Temp"


{{ArgTitle|3|backendDisableStorage|{{GVI|armaR|0.0.0}}}}
=== backendDisableStorage ===


{{hl|-backendDisableStorage}} disables use of storage, no loads or saves can be performed both online and '''local'''.
{{hl|-backendDisableStorage}} disables use of storage, no loads or saves can be performed both online and '''local'''.
Line 68: Line 78:
  ArmaReforgerSteam.exe -backendDisableStorage
  ArmaReforgerSteam.exe -backendDisableStorage


{{ArgTitle|3|backendFreshSession|{{GVI|armaR|0.0.0}}}}
=== backendFreshSession ===


{{hl|-backendFreshSession}} skips the initial load request from dedicated server's configuration file or from script - the DS Session basically starts as a brand new one, the rest of functionalities is not affected (saves, runtime loads, etc).
{{hl|-backendFreshSession}} skips the initial load request from dedicated server's configuration file or from script - the DS Session basically starts as a brand new one, the rest of functionalities is not affected (saves, runtime loads, etc).
Line 75: Line 85:
  ArmaReforgerSteam.exe -backendFreshSession
  ArmaReforgerSteam.exe -backendFreshSession


{{ArgTitle|3|backendLocalStorage|{{GVI|armaR|0.0.0}}}}
=== backendLocalStorage ===


{{hl|-backendLocalStorage}} forces Save & Load of player and general data normally sent to/received from the backend to work with local JSON files in profile folder instead.
{{hl|-backendLocalStorage}} forces Save & Load of player and general data normally sent to/received from the backend to work with local JSON files in profile folder instead.
Line 82: Line 92:
  ArmaReforgerSteam.exe -backendLocalStorage
  ArmaReforgerSteam.exe -backendLocalStorage


{{ArgTitle|3|freezeCheck|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|freezeCheck|{{GVI|armaR|1.2.0}}}}


{{hl|-freezeCheck}} overrides time in seconds to forcefully crash on application freeze or completely disable detection. Default 300 (5 minutes), range 0 (disabled) to 600 (10 minutes).
number value, range 0..600, default 300
 
{{hl|-freezeCheck}} overrides time in seconds to forcefully crash on application freeze or completely disable detection.
{{Feature|informative|Workbench has default time set to 1 minute and will only generate minidump without crashing.}}


; Example
; Example
  ArmaReforgerSteam.exe -freezeCheck 30
  ArmaReforgerSteam.exe -freezeCheck 30


{{ArgTitle|3|cfg|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|freezeCheckMode|{{GVI|armaR|1.2.0}}}}
 
string value, default minidump (workbench) or crash
 
{{hl|-freezeCheckMode}} overrides behavior which should happen when freeze is detected.
* {{hl|crash}} - force crashes the application
* {{hl|minidump}} - silently generates minidump and keeps application running until it unfreezes or is terminated by user
* {{GVI|armaR|1.3.0|size= 0.75}} {{hl|kill}} - will force kill the application - is more reliable than {hl|crash} but does not provide any data about the freeze
 
{{Feature|important|Option {{hl|minidump}} is supported only on Windows.}}
 
; Example
ArmaReforgerSteam.exe -freezeCheckMode crash
ArmaReforgerSteam.exe -freezeCheckMode minidump
 
=== cfg ===
 
{{hl|-cfg}} forces to load specific user engine settings config (things like graphics settings, window position and size etc).
{{hl|-cfg}} forces to load specific user engine settings config (things like graphics settings, window position and size etc).


=== GPUAdapter ===
=== GPUAdapter ===
Line 116: Line 144:
* [[File:flag_portugal.gif]] {{hl|pt_br}} - Portuguese
* [[File:flag_portugal.gif]] {{hl|pt_br}} - Portuguese
* [[File:flag_china.gif]] {{hl|zh_cn}} - Mandarin
* [[File:flag_china.gif]] {{hl|zh_cn}} - Mandarin
* {{GVI|armaR|1.2.0|size= 0.75}} [[File:flag_ukraine.gif]] {{hl|uk_ua}} - Ukrainian
}}
}}


Line 144: Line 173:
=== noThrow ===
=== noThrow ===


{{hl|-noThrow}} disables all kinds of error message dialogs. (VME's, asserts, crashes, ...).
{{hl|-noThrow}} disables all kinds of error message dialogs. (VMEs, asserts, crashes, ...).


; Example
; Example
Line 156: Line 185:
  ArmaReforgerSteam.exe -profile "David Armstrong" // targets {{hl|%userprofile%\My Documents\My Games\David Armstrong\profile}}
  ArmaReforgerSteam.exe -profile "David Armstrong" // targets {{hl|%userprofile%\My Documents\My Games\David Armstrong\profile}}
  ArmaReforgerSteam.exe -profile "C:\Users\MyUserName\Documents\ArmaReforgerDir" // targets {{hl|"C:\Users\MyUserName\Documents\ArmaReforgerDir\profile"}}
  ArmaReforgerSteam.exe -profile "C:\Users\MyUserName\Documents\ArmaReforgerDir" // targets {{hl|"C:\Users\MyUserName\Documents\ArmaReforgerDir\profile"}}


=== singleThreadedUpdate ===
=== singleThreadedUpdate ===
Line 203: Line 231:


{{hl|-forceUpdate}} forces the application to render and update even when the window is out of focus.
{{hl|-forceUpdate}} forces the application to render and update even when the window is out of focus.
{{Feature|informative|Previously known as {{Link|Arma 3: Startup Parameters#noPause|-noPause}} in earlier titles.}}


; Example
; Example
Line 219: Line 249:
{{Feature|important|These parameters apply to the Workbench executable.}}
{{Feature|important|These parameters apply to the Workbench executable.}}


=== buildData ===
=== forceSettings ===


{{hl|-forcesettings}} forces to use the specified Workbench settings from a file instead of the usual settings stored in Windows registry which will be entirely ignored.
The settings in a file will be used for reading and also writing.
This functionality is compatible with {{hl|wbSettingsDump.ini}} files being attached to crash reports.


{{Feature|informative|It is possible to export Workbench settings to an {{hl|.ini}} file from {{Link|Arma Reforger:Resource Manager: Options#Export settings|Workbench options}}.}}


=== gproj ===
=== gproj ===


{{hl|-gproj}}
{{hl|-gproj}} defines the addon project to be loaded - it can be used to skip the Workbench's addon selection screen.


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -gproj "C:\Program Files (x86)\Steam\steamapps\common\Arma Reforger\addons\data\ArmaReforger.gproj"
  ArmaReforgerWorkbenchSteamDiag.exe -gproj "C:\Program Files (x86)\Steam\steamapps\common\Arma Reforger\addons\data\ArmaReforger.gproj"


{{ArgTitle|3|gprojConfig|{{GVI|armaR|0.0.0}}}}
=== gprojConfig ===


{{hl|-gprojConfig}} forces loading the provided configuration e.g {{hl|PC}}, {{hl|HEADLESS}} etc.
{{hl|-gprojConfig}} forces loading the provided configuration e.g {{hl|PC}}, {{hl|HEADLESS}} etc.


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -gprojConfig PC
  ArmaReforgerWorkbenchSteamDiag.exe -gprojConfig PC


=== wbModule ===
=== wbModule ===


{{hl|-wbModule}} specifies which [[Arma Reforger:Workbench|Workbench]] module must be launched (with {{hl|[[#run|-run]]}}):
{{hl|-wbModule}} specifies which {{GameCategory|armaR|Modding|Official Tools|text= Workbench}} module must be launched (with {{hl|[[#run|-run]]}}):
 
{| class="wikitable"
{| class="wikitable"
! Editor
! Editor
Line 280: Line 315:
|}
|}


{{Feature|informative|
{{Feature|important|
* {{hl|-wbmodule}} requires an equal sign {{hl|{{=}}}} to work.
* Parameters specified after the module name are considered to be parameters to the module specifically.
* Parameters specified after the module name are considered to be parameters to the module specifically.
* The {{hl|[[#run|-run]]}} parameter must be added after each instance of {{hl|-wbmodule}} for them to launch.
* The {{hl|{{Link|#run|-run}}}} parameter must be added after each instance of {{hl|-wbModule}} for them to launch.
}}
}}


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbModule=WorldEditor -run
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run


=== plugin ===
=== plugin ===


{{hl|-plugin}} specifies which [[Arma Reforger:Workbench|Workbench]] plugin must be launched (WorldTestPlugin, TextureImportTool, MaterialImportTool, WorldDataExport etc).
{{hl|-plugin}} specifies which {{GameCategory|armaR|Modding|Official Tools|text= Workbench}} plugin must be launched (WorldTestPlugin, TextureImportTool, MaterialImportTool, WorldDataExport etc).


{{Feature|informative|
{{Feature|informative|
* Parameters specified after the plugin are considered to be parameters to the plugin specifically.
* Parameters specified after the plugin are considered to be parameters to the plugin specifically.
* Plugins are loaded for specific modules. Before loading a plugin specify the appropriate [[#wbmodule|wbmodule]].
* Plugins are loaded for specific modules. Before loading a plugin specify the appropriate [[#wbModule|wbModule]].
}}
}}


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -plugin=ResavePlugin pluginArguments
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -plugin=ResavePlugin pluginArguments


=== run ===
=== run ===


{{hl|-run}} tells the executable to open the designated Workbench module (specified by {{hl|[[#wbmodule|-wbmodule]]}} usage).
{{hl|-run}} tells the executable to open the designated Workbench module (specified by {{hl|[[#wbModule|-wbModule]]}} usage).


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=WorldEditor -run
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run


=== load ===
=== load ===


{{hl|-load}} tells the executable to open selected file in the designated Workbench module (specified by {{hl|[[#wbmodule|-wbmodule]]}} usage).
{{hl|-load}} tells the executable to open selected file in the designated Workbench module (specified by {{hl|[[#wbModule|-wbModule]]}} usage).
The file path can be specified either by absolute path, relative path, exact path or by resource name.
The file path can be specified either by absolute path, relative path, exact path or by resource name.


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=WorldEditor -run -load "world/myworld.ent"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "world/myworld.ent"


This will open up the [[Arma Reforger:World Editor|World Editor]] and load the {{hl|myworld.ent}} file.
This will open up the [[Arma Reforger:World Editor|World Editor]] and load the {{hl|myworld.ent}} file.
Line 326: Line 362:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -packAddon
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -packAddon


=== packAddonDir ===
=== packAddonDir ===
Line 333: Line 369:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -packAddon -packAddonDir "D:\build\Green"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -packAddon -packAddonDir "D:\build\Green"


=== publishAddon ===
=== publishAddon ===
Line 346: Line 382:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -publishAddon
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon


=== publishAddonDir ===
=== publishAddonDir ===
Line 354: Line 390:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -publishAddon -publishAddonDir "D:\build\Green"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon -publishAddonDir "D:\build\Green"


=== publishAddonVersion ===
=== publishAddonVersion ===
Line 362: Line 398:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -publishAddon -publishAddonVersion "2.3.5"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon -publishAddonVersion "2.3.5"


=== publishAddonChangeNote ===
=== publishAddonChangeNote ===
Line 369: Line 405:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -publishAddonChangeNote "Fix shading"
  ArmaReforgerWorkbenchSteamDiag.exe -publishAddonChangeNote "Fix shading"
 
=== publishAddonChangeNoteFile ===
 
{{hl|-publishAddonChangeNoteFile}} is an optional parameter which is used to specify this update's change note.
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -publishAddonChangeNoteFile "C:\Addon\changelog.txt"


=== publishAddonPreviewImage ===
=== publishAddonPreviewImage ===


{{hl|-publishAddonPreviewImage }} is an optional parameter that which you can use to specify path to preview image file.
{{hl|-publishAddonPreviewImage}} is an optional parameter which you can use to specify the preview image file's path.


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -publishAddonPreviewImage "z:/mymod/my_preview_image.jpg"
  ArmaReforgerWorkbenchSteamDiag.exe -publishAddonPreviewImage "z:/mymod/my_preview_image.jpg"


=== publishAddonScreenshots ===
=== publishAddonScreenshots ===


{{hl|-publishAddonScreenshots}} is an optional parameter that specify folder from where the screenshots should be taken. It is then automatically scanned for all valid image file types (jpg, png, bmp).
{{hl|-publishAddonScreenshots}} is an optional parameter that specifies the directory from where the screenshots should be taken. It is then automatically scanned for all valid image file types (jpg, png, bmp).


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -publishAddonScreenshots "Z:/mymod/screenshots"
  ArmaReforgerWorkbenchSteamDiag.exe -publishAddonScreenshots "Z:/mymod/screenshots"
 
=== rebuild-database-only ===
 
{{hl|-rebuild-database-only}} makes Workbench automatically exit when the database file is refreshed. This is useful for creating game packages which should be distributed with the latest database file.
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -rebuild-database-only


=== scrDefine ===
=== scrDefine ===
Line 398: Line 448:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
  ArmaReforgerWorkbenchSteamDiag.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
  ArmaReforgerSteam.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
  ArmaReforgerSteam.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
  ArmaReforgerServer.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
  ArmaReforgerServer.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
{{ArgTitle|3|scrNoInline|{{GVI|armaR|1.1.0}}}}
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{hl|-scrNoInline}} disables inline optimisation for debug purposes.
; Example
ArmaReforgerSteam'''Diag'''.exe -scrNoInline


=== wbBackendLogin ===
=== wbBackendLogin ===
Line 407: Line 466:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbBackendLogin [email protected] myPassword
  ArmaReforgerWorkbenchSteamDiag.exe -wbBackendLogin [email protected] myPassword


=== noGameScriptsOnInit ===
=== noGameScriptsOnInit ===
Line 417: Line 476:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -noGameScriptsOnInit
  ArmaReforgerWorkbenchSteamDiag.exe -noGameScriptsOnInit


=== enableWARP ===
=== enableWARP ===
Line 425: Line 484:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -enableWARP
  ArmaReforgerWorkbenchSteamDiag.exe -enableWARP


=== clearSettings ===
{{ArgTitle|3|clearSettings|{{GVI|armaR|0.9.7}}}}


{{hl|-clearSettings}}, as its name suggests, clears all Workbench user preference - window positions, preview settings, last opened files etc.
{{hl|-clearSettings}}, as its name suggests, clears all Workbench user preference - window positions, preview settings, last opened files etc.


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -clearSettings
ArmaReforgerWorkbenchSteamDiag.exe -clearSettings
 
{{ArgTitle|3|exitAfterInit|{{GVI|armaR|1.1.0}}}}
 
{{hl|-exitAfterInit}} makes Workbench automatically exit once it is completely initialised and all startup parameters are executed.
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -exitAfterInit
 
{{ArgTitle|3|diagMenu|{{GVI|armaR|1.1.0}}}}
 
{{hl|-diagMenu}} overrides where diagnostic menu saved settings are stored (see hints section of [[Arma Reforger:Diag Menu]] ).
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -diagMenu "file.txt"
 
 
== Workbench - AnimationEditor Module ==
 
=== animDebugger ===
 
{{Feature|important|This parameter only works on '''diag exe'''!}}
 
{{hl|-animDebugger}} enables animation debugging.
 
; Example
  ArmaReforgerWorkbenchSteam'''Diag'''.exe -animDebugger




== Workbench - LocalizationEditor Module ==
== Workbench - LocalizationEditor Module ==
=== build ===
{{hl|-build}} creates runtime string tables from the opened string table.
; Example: -wbModule=LocalizationEditor -run -load {C014582791ECBF24}Language/localization.st -build -saveDir C:\tmp\
For building also hidden items from the localisation database, use {{hl|-scrDefine LOCALIZATION_BUILD_HIDDEN}}:
ArmaReforgerWorkbenchSteamDiag.exe -scrDefine LOCALIZATION_BUILD_HIDDEN -wbModule=LocalizationEditor -run -load {C014582791ECBF24}Language/localization.st -build -saveDir C:\tmp\
=== saveDir ===
{{hl|-saveDir}} specifies the (absolute) save directory for the module's {{hl|build}} command.
; Example
see above
== Workbench - NavmeshGeneratorMain Module ==
== Workbench - NavmeshGeneratorMain Module ==


Line 445: Line 547:
  // This opens up the World Editor with {{hl|myworld.ent}} loaded, connects Navmesh Editor to it and starts navmesh generation of the specified navmesh projects.
  // This opens up the World Editor with {{hl|myworld.ent}} loaded, connects Navmesh Editor to it and starts navmesh generation of the specified navmesh projects.
  // Navmesh Editor generates the navmesh and saves it to the path originally held by NavmeshWorldEntity in the world.
  // Navmesh Editor generates the navmesh and saves it to the path originally held by NavmeshWorldEntity in the world.
  ArmaReforgerWorkbenchSteam.exe -wbmodule=NavmeshGeneratorMain -run -autogenerate "world/myworld.ent"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=NavmeshGeneratorMain -run -autogenerate "world/myworld.ent"


navmesh projects are optional and can be {{hl|ALL}} to generate all projects.
navmesh projects are optional and can be {{hl|ALL}} to generate all projects.
=== saveDir ===
{{hl|-saveDir}} is an optional parameter that defines in which directory the data will be exported.
; Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=NavmeshGeneratorMain -run -autogenerate "world/myworld.ent" -saveDir "C:/temp/output/"
=== logNavmeshGen ===
{{hl|-logNavmeshGen}} logs output from changing states of the navmesh generator state machine.
{{Feature|informative|This parameter does nothing at the moment as it is always enabled.}}


== Workbench - ResourceManager Module ==
== Workbench - ResourceManager Module ==


{{ArgTitle|3|buildData|{{GVI|armaR|0.0.0}}}}
=== buildData ===


{{hl|-buildData}} builds all data of one addon in a specified directory. Without addon specification, it builds data of the current addon (usually a game).
{{hl|-buildData}} builds all data of one addon in a specified directory. Without addon specification, it builds data of the current addon (usually a game).
Line 458: Line 573:
; Example 1
; Example 1
  This builds data of a current addon
  This builds data of a current addon
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -builddata PC "C:\Data\PCData"
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -builddata PC "C:\Data\PCData"


; Example 2
; Example 2
  This builds data of a specific addon called "ArmaReforger"
  This builds data of a specific addon called "ArmaReforger"
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -builddata PC "C:\Data\PCData" ArmaReforger
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -builddata PC "C:\Data\PCData" ArmaReforger


This will build PC data to the provided directory. Possible options for the platform name are PC, PC_WB, XBOX_ONE, XBOX_SERIES, PS4, HEADLESS.
This will build PC data to the provided directory. Possible options for the platform name are PC, PC_WB, XBOX_ONE, XBOX_SERIES, PS4, HEADLESS.
Line 477: Line 592:


; Example
; Example
  ArmaReforgerWorkbenchSteam.exe -wbmodule=ResourceManager -builddata PC "C:\Data\PCData" -metaFiles
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -buildData PC "C:\Data\PCData" -metaFiles
 
=== loadBuiltData ===
 
{{hl|-loadBuiltData}} is an optional parameter which may be used together with {{Link|#buildData|-buildData}} - built resource is loaded into memory and possible errors are printed into the log. Useful for identifying broken resources.
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData PC "C:\Data\PCData" -metaFiles -loadBuiltData
 
=== includeTypes ===
{{hl|-includeTypes}} is an optional parameter which may be used together with {{Link|#buildData|-buildData}} - it specifies a list of file types (separated by a comma) that will be included in data build. Can be combined together with {{Link|#excludeTypes|-excludeTypes}}
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -builddata PC "c:\Data\PCData" -metaFiles -includeTypes "edds,xob,emat"
 
=== excludeTypes ===
 
{{hl|-excludeTypes}} is an optional parameter which may be used together with {{Link|#buildData|-buildData}} - it specifies a list of file types (separated by a comma) that will not be included in data build. Can be combined together with {{Link|#excludeTypes|-includeTypes}}
 
; Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -builddata PC "C:\Data\PCData" -metaFiles -excludeTypes "nmn,ent,terr"
 
=== filterPath ===
 
{{hl|-filterPath}} is an optional parameter which may be used together with {{Link|#buildData|-buildData}} - it allows to limit data build to only a single folder or file.
 
; Example 1
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData -filterPath "c:\Data\ArmaReforger\worlds\Arland"
This limits that only data from this specific folder will go to data build
 
; Example 2
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData -filterPath "c:\Data\ArmaReforger\worlds\Arland\Arland.ent"
This limits that only data that belong to {{hl|Arland.ent}} will go to data build (ent, smap, smd, ...)
 
=== filterTags ===
 
{{hl|-filterTags}} is an optional parameter which may be used together with {{Link|#buildData|-buildData}} - it can be used to exclude/include particular files and folders from/to data build.
It is based on tagging files and folders through the "Build Tags" property which is part of file/folder import settings. This parameter has a form of a C++ expression where can be used only string tags and these three operators:
 
* '''&''' - logical AND
* '''|''' - logical OR
* '''!''' - logical NOT
 
; Examples:
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "!wbOnly & !testOnly & !consolesOnly"
This includes to build everything except files and folders tagged as wbOnly or testOnly or consolesOnly
 
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly"
This includes to build only files and folders tagged as wbOnly
 
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly & !testOnly"
This includes to build only files and folders tagged as wbOnly but without those of them that are tagged as testOnly
 
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly | testOnly"
This includes to build only files and folders tagged as wbOnly or testOnly
 
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "(!wbOnly & !testOnly) | alwaysIncluded"
This includes to build everything except files and folders tagged as wbOnly or testOnly. If some file or folder is tagged with alwaysIncluded it will be included even though it's located inside a wbOnly folder for example
 
=== wbSilent ===
 
{{hl|-wbsilent}} initialises the engine, workbench modules and exit without opening any windows; it can be used to validate engine/game initialisation and script compilation.
 


== Workbench - ScriptEditor Module ==
== Workbench - ScriptEditor Module ==
=== validate ===
string value, default ALL
{{hl|-validate}} checks if the game scripts are compilable and returns Workbench application return code of "-1" when compilation failed and "0" when compilation was successful.
Value is optional and script configuration name is expected (Configurations can be found in project settings, it is usually PC, XBOX_SERIES, etc).
== Workbench - WorldEditor Module ==
== Workbench - WorldEditor Module ==


=== forceSaveAll ===
{{ArgTitle|3|forceSaveAll|{{GVI|armaR|1.1.0}}}}


{{hl|-forceSaveAll}}
{{hl|-forceSaveAll}}
Line 489: Line 675:


; Example 1 (normal edit mode)
; Example 1 (normal edit mode)
  ArmaReforgerWorkbenchSteam.exe -wbmodule=WorldEditor -run -load "world/myworld.ent" -forceSaveAll
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "world/myworld.ent" -forceSaveAll


; Example 2 (prefab edit mode)
; Example 2 (prefab edit mode)
  ArmaReforgerWorkbenchSteam.exe -wbmodule=WorldEditor -run -load "Prefabs/Structures/Houses/Villa/Villa_E_2I01/Villa_E_2I01.et" -forceSaveAll
  ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "Prefabs/Structures/Houses/Villa/Villa_E_2I01/Villa_E_2I01.et" -forceSaveAll
 


== Hosting ==
== Hosting ==
Line 515: Line 702:


{{hl|-autoreload}} reloads the scenario when the session ends after the provided delay, without shutting down the server. Value is in seconds.
{{hl|-autoreload}} reloads the scenario when the session ends after the provided delay, without shutting down the server. Value is in seconds.
{{GVI|armaR|1.3.0}} the {{hl|disabled}} value makes the ''server'' restart and relaunch as the same instance.


; Example
; Example
  ArmaReforgerServer.exe -autoreload 10
  ArmaReforgerServer.exe -autoreload 10
{{ArgTitle|3|autoshutdown|{{GVI|armaR|1.3.0}}}}
{{hl|-autoshutdown}} ensures the correct server shutdown process.
To give 30 seconds post game and then shutdown:
; Example
ArmaReforgerServer.exe -autoreload 30 -autoshutdown
{{Feature|gvi|armaR|1.3.0|
To circumvent 1.3.0's server restart issue, make sure to use this command and configure the server to automatically restart on failure or shutdown.
}}


=== bindIP ===
=== bindIP ===
Line 540: Line 741:
; Example
; Example
  ArmaReforgerServer.exe -config myConfigFile.json
  ArmaReforgerServer.exe -config myConfigFile.json
{{ArgTitle|3|forceDisableNightGrain|{{GVI|armaR|1.6.0}}}}
{{hl|-forceDisableNightGrain}} disables night grain in multiplayer.
{{Feature|informative|Single player already disables night grain.}}
; Example
ArmaReforgerServer.exe -forceDisableNightGrain


=== listScenarios ===
=== listScenarios ===


{{hl|-listScenarios}} prints to game logs the scenario .conf file paths.
{{hl|-listScenarios}} prints to game logs the scenario .conf file paths.
{{Feature|informative|Workshop scenarios will only be listed if no scenario is being loaded (through e.g a {{Link|#config}}).}}
{{Feature|informative|
* Workshop scenarios will only be listed if no scenario is being loaded (through e.g a {{Link|#config}}).
* A list of official scenarios can be found on {{Link|Arma Reforger:Server Config#scenarioId}}.
}}


; Example
; Example
  ArmaReforgerServer.exe -listScenarios
  ArmaReforgerServer.exe -listScenarios


; Result
{{ArgTitle|3|loadSessionSave|{{GVI|armaR|1.0.0}}{{GVI|armaR|1.6.0}}}}
{{GVI|armaR|0.9.9}} <spoiler text="Show Scenarios">
 
e.g:
{{hl|-loadSessionSave}} allows the game to load a previous game session.
: --------------------------------------------------
 
: Official scenarios (8 entries)
It can be used alone to load the latest save, or with a specific save file name.
: --------------------------------------------------
When left empty, it will attempt to locate the latest save game data for the current scenario on launch.
: {ECC61978EDCC2B5A}Missions/23_Campaign.conf (Conflict - Everon)
Optionally, as a parameter, the UUID of a specific save can be passed, which is found inside each save point's {{hl|meta-info.json}} file.
: {59AD59368755F41A}Missions/21_GM_Eden.conf (Game Master - Everon)
 
: {90F086877C27B6F6}Missions/99_Tutorial.conf (Tutorial)
; Examples
: {2BBBE828037C6F4B}Missions/22_GM_Arland.conf (Game Master - Arland)
  ArmaReforgerSteam.exe -loadSessionSave
: {C700DB41F0C546E1}Missions/23_Campaign_NorthCentral.conf (Conflict - Northern Everon)
  ArmaReforgerSteam.exe -loadSessionSave 07e8fa26-d5b6-47f6-a19b-641c72ab05bc
: {28802845ADA64D52}Missions/23_Campaign_SWCoast.conf (Conflict - Southern Everon)
  ArmaReforgerServer.exe -loadSessionSave
  : {DAA03C6E6099D50F}Missions/24_CombatOps.conf (Combat Ops - Arland)
  ArmaReforgerServer.exe -loadSessionSave 0d51b792-2a66-47d2-b71a-09086cffba3a
  : {C41618FD18E9D714}Missions/23_Campaign_Arland.conf (Conflict - Arland)
 
: --------------------------------------------------
{{ArgTitle|3|keepSessionSave|{{GVI|armaR|1.6.0}}}}
  : Workshop scenarios (8 entries)
 
  : --------------------------------------------------
{{hl|-keepSessionSave}} keeps any save data for completed playthroughs on the game's end screen.
: {6EA2E454519E5869}Missions/CAH_Military_Base.conf
 
: {7C491B1FCC0FF0E1}Missions/CAH_LeMoule.conf
; Example
: {F1A1BEA67132113E}Missions/CAH_Castle.conf
  ArmaReforgerSteam.exe -keepSessionSave
: {589945FB9FA7B97D}Missions/CAH_Concrete_Plant.conf
: {2B4183DF23E88249}Missions/CAH_Morton.conf
: {3F2E005F43DBD2F8}Missions/CAH_Briars_Coast.conf
: {9405201CBD22A30C}Missions/CAH_Factory.conf
  : {1CD06B409C6FAE56}Missions/CAH_Forest.conf
: --------------------------------------------------
</spoiler>


=== logStats ===
=== logStats ===
Line 602: Line 808:


{{Feature|important|The memory usage reported by {{hl|-logStats}} is a server approximation and is therefore not 100% accurate when compared with the operating system values.}}
{{Feature|important|The memory usage reported by {{hl|-logStats}} is a server approximation and is therefore not 100% accurate when compared with the operating system values.}}
{{ArgTitle|3|logVoting|{{GVI|armaR|1.3.0<!--.157-->}}}}
{{hl|-logVoting}} adds logging info to the voting system with information about who created, voted, and against whom the vote was created.
; Example
ArmaReforgerServer.exe -logVoting


=== maxFPS ===
=== maxFPS ===
Line 613: Line 826:
=== server ===
=== server ===


This parameter instructs the executable to launch '''local''' server and '''load selected world'''.  When this parameter is used, config is ignored. Server parameter can be combined with {{Link|Arma Reforger:Startup Parameters#addons|addons}} & {{Link|Arma Reforger:Startup Parameters#addonsDir|addonsDir}} parameters to start a server with local mods, which can be useful when testing addon before uploading it Workshop.
This parameter instructs the executable to launch '''local''' server and '''load selected world'''.  When this parameter is used, config is ignored. Server parameter can be combined with {{Link|#addons}} & {{Link|#addonsDir}} parameters to start a server with local mods, which can be useful when testing addon before uploading it Workshop.
  ArmaReforgerServer.exe -server "worlds/MP/MPTest.ent" -addonsDir "C:\MyModsDir" -addons MyCustomMod
  ArmaReforgerServer.exe -server "worlds/MP/MPTest.ent" -addonsDir "C:\MyModsDir" -addons MyCustomMod
{{Feature|important|These parameters apply to the Game executable.}}
{{Feature|important|These parameters apply to the Game executable.}}
Line 625: Line 838:


; Example #2
; Example #2
; This will connect game to a [[Arma Reforger:Startup Parameters#server|locally hosted dedicated server]] and load the local MyCustomMod addon
This will connect the game to a {{Link|#server|locally hosted dedicated server}} and load the local MyCustomMod addon:
  ArmaReforgerSteam.exe -client -addonsDir "C:\MyModsDir" -addons MyCustomMod
  ArmaReforgerSteam.exe -client -addonsDir "C:\MyModsDir" -addons MyCustomMod
{{ArgTitle|3|worldSystemsConfig|{{GVI|armaR|1.6.0}}}}
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{hl|-worldSystemsConfig}} allows setting a world systems config file (of type <enforce inline>SystemSettings</enforce>) '''when starting a mission directly''' (''not'' via {{hl|MissionHeader.conf}}).
; Example
ArmaReforgerSteam'''Diag'''.exe -worldSystemsConfig "{C50579A2EC48E8EF}Configs/Systems/MissionSystems.conf"
{{ArgTitle|3|addonsVerify|{{GVI|armaR|1.3.0}}}}
{{Feature|important|This parameter only works on '''dedicated server'''!}}
Verifies the integrity of all installed addons. If any corrupted addons are found, the server will shut down and log the corrupted files. The verification may take some time depending on the size of the addons.
{{ArgTitle|3|addonsRepair|{{GVI|armaR|1.3.0}}}}
{{Feature|important|This parameter only works on '''dedicated server'''!}}
Verifies the integrity of all installed addons. If any corrupted addons are found, they will be repaired automatically. If the repair fails, the server will shut down.
The repair duration depends on the addons size and the amount of data which needs to be repaired.




Line 635: Line 868:
=== nds ===
=== nds ===


{{hl|-nds}} Network Dynamic Simulation (nds) is a server feature that only streams in relevant replicated entities for each client. the provided value stands for diameter, or the number of cells which are being replicated - default is 2 in each direction. To turn the feature off use {{hl|-nds 0}}. A higher diameter will result in a bigger networked view range, lower server performance.
number value, default 2
 
{{hl|-nds}} Network Dynamic Simulation (nds) is a server feature that only streams in relevant replicated entities for each client.
The provided value stands for diameter, or the number of cells which are being replicated.
To turn the feature off use {{hl|-nds 0}}. A higher diameter will result in a bigger networked view range, lower server performance.


; Example
; Example
Line 642: Line 879:
=== nwkResolution ===
=== nwkResolution ===


{{hl|-nwkResolution}} defines what resolution Spatial Map cells should be set at in a 100..1000m range. Smaller resolution will result in less "pop-in" but lower networked view range. For high view range use high resolution, but small diameter.
{{hl|-nwkResolution}} defines what resolution Spatial Map cells should be set at in a 100..1000m range. Smaller resolution will result in less "pop-in" but lower networked view range.
For high view range use high resolution, but small diameter.


; Example
; Example
  ArmaReforgerServer.exe -nwkResolution 500
  ArmaReforgerServer.exe -nwkResolution 500


=== rpl-reconnect ===
=== rpl-timeout-ms ===


{{hl|-rpl-reconnect}} makes the replication try to reconnect instead of immediately raising connection failure.
{{hl|-rpl-timeout-ms}} sets the client/server timeout's value, in milliseconds.
{{Feature|important|Endless reconnection loop is designed for debug purposes only.}}


; Example
; Example
  ArmaReforgerServer.exe -rpl-reconnect
  ArmaReforgerServer.exe -rpl-timeout-ms 10000


=== rpl-timeout-disable ===
=== rpl-timeout-disable ===


{{hl|-rpl-timeout-disable}} disables client/server timeout.
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{Feature|important|
 
If a connection stops responding, the server performance will start deteriorating until it will eventually run out of memory and crash.
{{hl|-rpl-timeout-disable}} disables the client/server timeout.
This parameter is strictly for debugging purposes.
{{Feature|important|If a connection stops responding, the server's performance will deteriorate until it eventually runs out of memory and crash. This parameter is strictly for debugging purposes.}}
}}
 
; Example
ArmaReforgerSteam'''Diag'''.exe -rpl-timeout-disable
 
=== rpl-reconnect ===
 
{{Feature|important|This parameter only works on '''diag exe''', on '''client'''!}}
 
The replication tries to reconnect instead of immediately raising connection.


; Example
; Example
  ArmaReforgerServer.exe -rpl-timeout-disable
  ArmaReforgerSteam'''Diag'''.exe -rpl-reconnect


=== rpl-timeout-ms ===
=== rpl-vcons ===
 
number value, range 0..200, default 0
 
{{Feature|important|This parameter only works on '''diag exe'''!}}


{{hl|-rpl-timeout-ms}} sets the client/server timeout's value, in milliseconds.
{{hl|-rpl-vcons}} sets the number of virtual connections.


; Example
; Example
  ArmaReforgerServer.exe -rpl-timeout-ms 10000
  ArmaReforgerSteam'''Diag'''.exe -rpl-vcons 5


=== rpl-validation-rdb-disable ===
=== rpl-validation-rdb-disable ===
{{Feature|important|This parameter only works on '''diag exe'''!}}


{{hl|-rpl-validation-rdb-disable}} disables the validation of clients resource database.
{{hl|-rpl-validation-rdb-disable}} disables the validation of clients resource database.
{{Feature|important|This should not be disabled in normal usage conditions. This is for development purpose only!}}
{{Feature|warning|Make sure you know what you are doing first before disabling the validation as data mismatch may bring undefined behaviour!}}


; Example
; Example
  ArmaReforgerServer.exe -rpl-validation-rdb-disable
  ArmaReforgerSteam'''Diag'''.exe -rpl-validation-rdb-disable


=== rpl-validation-scr-disable ===
=== rpl-validation-scr-disable ===


Disables the validation of clients scripts checksum.
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{Feature|important|This should not be disabled in normal usage conditions. This is for development purpose only!}}
 
{{hl|-rpl-validation-scr-disable}} disables the validation of clients scripts checksum.
{{Feature|warning|Make sure you know what you are doing first before disabling the validation as script mismatch may bring undefined behaviour!}}


; Example
; Example
  ArmaReforgerServer.exe -rpl-validation-scr-disable
  ArmaReforgerSteam'''Diag'''.exe -rpl-validation-scr-disable


=== rpl-validation-version-disable ===
=== rpl-validation-version-disable ===


Disables the validation of clients executable version.
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{Feature|important|This should not be disabled in normal usage conditions. This is for development purpose only!}}
 
{{hl|-rpl-validation-version-disable}} disables the validation of clients executable version.
{{Feature|warning|Make sure you know what you are doing first before disabling the validation as version mismatch may bring undefined behaviour!}}


; Example
; Example
  ArmaReforgerServer.exe -rpl-validation-version-disable
  ArmaReforgerSteam'''Diag'''.exe -rpl-validation-version-disable
 
=== rpl-validation-devbin-disable ===
 
{{Feature|important|This parameter only works on '''diag exe'''!}}
 
{{hl|-rpl-validation-devbin-disable}} disables the validation of developer binary flag, allowing mixing developer and non-developer binaries in the same multiplayer session.


=== staggeringBudget ===
=== staggeringBudget ===


{{hl|-staggeringBudget}} defines how many stationary spatial map cells are allowed to be processed in one tick in 1..10201 range. If not set it uses "{{Link|#nds|-nds}}" diameter. A lower number will limit how many cells the server has to process per tick, but increase the time it takes for a client to have all relevant entities streamed in, if the server experiences significant performance drops on spawning/teleporting then the number is set too high, if you the client experiences "pop-in" of replicated items then the number is set too low.
{{hl|-staggeringBudget}} defines how many stationary spatial map cells are allowed to be processed in one tick in 1..10201 range. If not set it uses "{{Link|#nds|-nds}}" diameter.
A lower number will limit how many cells the server has to process per tick, but increase the time it takes for a client to have all relevant entities streamed in.
If the server experiences significant performance drops on spawning/teleporting then the number is set too high, if the client experiences "pop-in" of replicated items then the number is set too low.


; Example
; Example
Line 706: Line 969:
=== streamingBudget ===
=== streamingBudget ===


{{hl|-streamingBudget}} is the global streaming budget that is equally distributed between all connections. To decrement the budget, it uses the replicated hierarchy size of each entity that needs to be streamed in. It cannot go under 100 to prevent the system stalling. A lower number will limit how many entities the server has to process per tick, but increase the time it takes for a client to have that entity streamed in, if the server experiences significant performance drops on spawning/teleporting then the number is set too high, if the client experiences "pop-in" of replicated items then the number is set too low.
{{hl|-streamingBudget}} is the global streaming budget that is equally distributed between all connections.
To decrement the budget, it uses the replicated hierarchy size of each entity that needs to be streamed in. It cannot go under 100 to prevent the system stalling.
A lower number will limit how many entities the server has to process per tick, but increase the time it takes for a client to have that entity streamed in, if the server experiences significant performance drops on spawning/teleporting then the number is set too high, if the client experiences "pop-in" of replicated items then the number is set too low.


; Example
; Example
Line 713: Line 978:
=== streamsDelta ===
=== streamsDelta ===


{{hl|-streamsDelta}} is a tool to limit the amount of streams being opened for a client in range 1..1000 (default 100). If the difference between 'the number of streams the server has open' and 'the number of streams the client has open' is larger than the NUMBER then the server will not open any more streams this tick. To be adjusted based on average client networking speed.
number value, range 1..1000, default 100
 
{{hl|-streamsDelta}} is a tool to limit the amount of streams being opened for a client.
If the difference between 'the number of streams the server has open' and 'the number of streams the client has open' is larger than the NUMBER then the server will not open any more streams this tick.
To be adjusted based on average client networking speed.


; Example
; Example
Line 733: Line 1,002:
  ArmaReforgerSteam.exe -AILimit 0
  ArmaReforgerSteam.exe -AILimit 0


{{ArgTitle|3|AIPartialSim|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|AIPartialSim|{{GVI|armaR|1.0.0}}}}
 
number value, default: 4


{{hl|-aiPartialSim}} sets in how many batches before all AIs (as if in LOD0) will be processed
{{hl|-aiPartialSim}} sets in how many batches all simulable AIs will divided and processed.<br>
e.g: 150 AIs, 100 simulable AIs (100 in LOD0, 50 in LOD 10), these 100 AIs divided by 4 will make four batches of 25 AIs each.


; Example
; Example
  ArmaReforgerSteam.exe -aiPartialSim 5
  ArmaReforgerSteam.exe -aiPartialSim 5
{{ArgTitle|3|autodeployFaction|{{GVI|armaR|1.0.0}}}}
''alias: tdmf''
{{hl|-autodeployFaction}} overrides respawn faction (e.g US, USSR, FIA etc).
{{Feature|important|This parameter only works on '''diag exe'''!}}
; Example
ArmaReforgerSteam'''Diag'''.exe -autodeployFaction US
{{ArgTitle|3|autodeployLoadout|{{GVI|armaR|1.0.0}}}}
''alias: tdml''
{{Feature|important|This parameter only works on '''diag exe'''!}}
{{hl|-autodeployLoadout}} overrides respawn role (using role name from scenario's LoadoutManager).
; Example
ArmaReforgerSteam'''Diag'''.exe -autodeployLoadout #AR-Role_Driver
=== createDB ===
{{hl|-createDB}} forces database file's regeneration. Useful after file directories changes, when some resources were moved elsewhere.
Takes a few seconds upon start.
; Example
ArmaReforgerServer.exe -createDB


=== debugger ===
=== debugger ===
string value, default localhost


{{hl|-debugger}} sets the script debugger to a specific address.
{{hl|-debugger}} sets the script debugger to a specific address.
{{Feature|informative|The default value is localhost.}}


; Example
; Example
Line 749: Line 1,052:


=== debuggerPort ===
=== debuggerPort ===
number value, default 1000


{{hl|-debuggerPort}} sets the script debugger to a specific port.
{{hl|-debuggerPort}} sets the script debugger to a specific port.
{{Feature|informative|The default value is 1000.}}


; Example
; Example
  ArmaReforgerServer.exe -debuggerPort 1040
  ArmaReforgerServer.exe -debuggerPort 1040


{{ArgTitle|3|disableAI|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|disableAI|{{GVI|armaR|1.1.0}}}}


{{hl|-disableAI}} disables AIWorld initialisation and ticking.
{{hl|-disableAI}} disables AIWorld initialisation and ticking.
Line 765: Line 1,069:


; Example
; Example
  ArmaReforger.exe -disableCrashReporter
  ArmaReforgerSteam.exe -disableCrashReporter


{{ArgTitle|3|disableNavmeshStreaming|{{GVI|armaR|0.0.0}}}}
{{ArgTitle|3|disableNavmeshStreaming|{{GVI|armaR|1.1.0}}}}


{{hl|-disableNavmeshStreaming}} disables navmesh streaming on all navmesh worlds.
{{hl|-disableNavmeshStreaming}} disables navmesh streaming on all navmesh worlds.
{{GVI|armaR|1.2.0|size= 0.75}} added navmesh projects list support ("BTRlike" for vehicles, "Soldiers" for characters), separated by commas.
; Example
ArmaReforgerSteam.exe -disableNavmeshStreaming
ArmaReforgerSteam.exe -disableNavmeshStreaming NAVMESH_PROJECT1,NAVMESHPROJECT2,etc // >= 1.2.0


=== disableShadersBuild ===
=== disableShadersBuild ===
Line 784: Line 1,094:
; Example
; Example
  ArmaReforgerServer.exe -generateShaders
  ArmaReforgerServer.exe -generateShaders
{{ArgTitle|3|rplEncodeAsLongJobs|{{GVI|armaR|1.1.0}}}}
{{hl|-rplEncodeAsLongJobs}} makes replication use long encoding jobs instead of short ones.
; Example
ArmaReforgerServer.exe -rplEncodeAsLongJobs
{{ArgTitle|3|jobsysShortWorkerCount|{{GVI|armaR|1.1.0}}}}
{{hl|-jobsysShortWorkerCount}} sets the number of threads working on short jobs (jobs that must finish in one update loop).
Value is limited to the number of CPUs or 16, whichever is the lowest.
; Example
ArmaReforgerServer.exe -jobsysShortWorkerCount 4
{{ArgTitle|3|jobsysLongWorkerCount|{{GVI|armaR|1.1.0}}}}
number value, range 1..CPUCount, default ''{{Link|#jobsysShortWorkerCount}} / 2''
{{hl|-jobsysLongWorkerCount}} sets the number of threads working on long jobs (jobs that can span multiple iterations of update loop).
; Example
ArmaReforgerServer.exe -jobsysLongWorkerCount 4


{{ArgTitle|3|keepNumOfLogs|{{GVI|armaR|0.9.8}}}}
{{ArgTitle|3|keepNumOfLogs|{{GVI|armaR|0.9.8}}}}


{{hl|-keepNumOfLogs}} sets the maximum amount of logs to keep (default: 10).
number value, default: 10
 
{{hl|-keepNumOfLogs}} sets the maximum amount of logs to keep.


; Example
; Example
Line 815: Line 1,151:
=== logFS ===
=== logFS ===


{{hl|-logFS}} logs every ''F'''ile '''S'''ystem's read/write operation in {{hl|filesystem.log}}. This option is very demanding and can produce a big file in a short time, so it is to use with caution for debug purpose.
{{hl|-logFS}} logs every ''F'''ile '''S'''ystem's read/write operation in {{hl|filesystem.log}}. This option is very demanding and can produce a big file in a short time, so it is to be used with caution for debug purpose only.


; Example
; Example
Line 836: Line 1,172:
; Example
; Example
  ArmaReforgerSteam.exe -logLevel warning
  ArmaReforgerSteam.exe -logLevel warning
{{ArgTitle|3|logTime|{{GVI|armaR|1.3.0}}}}
string value, default time
{{hl|-logTime}} sets log line time's format; can be one of:
* none
* time (default)
* datetime
; Example
ArmaReforgerServer.exe -logTime datetime


{{ArgTitle|3|logsDir|{{GVI|armaR|0.9.8}}}}
{{ArgTitle|3|logsDir|{{GVI|armaR|0.9.8}}}}
Line 845: Line 1,193:
  ArmaReforgerSteam.exe -logsDir "C:\Users\MyUserName\Documents\ArmaReforgerDir" // targets {{hl|"C:\Users\MyUserName\Documents\ArmaReforgerDir"}} directly
  ArmaReforgerSteam.exe -logsDir "C:\Users\MyUserName\Documents\ArmaReforgerDir" // targets {{hl|"C:\Users\MyUserName\Documents\ArmaReforgerDir"}} directly


=== noCrashDialog ===
=== keepCrashFiles ===


{{hl|-noCrashDialog}} skips Crash Reporter's dialog and automatically sends crash reports.
{{hl|-keepCrashFiles}} prevents Crash Reporter from cleaning crash files on successful crash sending.


; Example
; Example
  ArmaReforgerSteam.exe -noCrashDialog
  ArmaReforgerSteam.exe -keepCrashFiles


=== keepCrashFiles ===
{{ArgTitle|3|minidump|{{GVI|armaR|1.1.0}}}}


{{hl|-keepCrashFiles}} prevents Crash Reporter from cleaning crash files on successful crash sending.
{{hl|-minidump}} allows minidump generation to include additional data; possible values:
{| class="wikitable"
! Value
! Microsoft Equivalent<br>(see {{Link|https://learn.microsoft.com/en-us/windows/win32/api/minidumpapiset/ne-minidumpapiset-minidump_type#constants|minidump API documentation}})
|-
| normal
| MiniDumpNormal
|-
| dataSegs
| MiniDumpWithDataSegs
|-
| fullMemory
| MiniDumpWithFullMemory
|}


; Example
; Example
  ArmaReforgerSteam.exe -keepCrashFiles
  ArmaReforgerSteam.exe -minidump fullMemory


=== scriptAuthorizeAll ===
=== scriptAuthorizeAll ===
Line 865: Line 1,226:
; Example
; Example
  ArmaReforgerSteam.exe -scriptAuthorizeAll
  ArmaReforgerSteam.exe -scriptAuthorizeAll
{{ArgTitle|3|silentCrashReport|{{GVI|armaR|1.0.0}}}}
{{hl|-silentCrashReport}} suppresses the Crash Reporter's dialog and automatically sends the report without any user input or message.
; Example
ArmaReforgerWorkbenchSteamDiag.exe -silentCrashReport
''was '''noCrashDialog''' before 1.0.0''


=== VMErrorMode ===
=== VMErrorMode ===
Line 884: Line 1,254:
  ArmaReforgerSteam.exe -checkInstance
  ArmaReforgerSteam.exe -checkInstance
<!--
<!--
=== scriptExtProfiler ===
{{ArgTitle|3|scriptExtProfiler|{{GVI|armaR|0.0.0}}}}


{{hl|-scriptExtProfiler}} turns on script VM's support for external [[Arma Reforger:Script Profiling|Script Profiling]].
{{hl|-scriptExtProfiler}} turns on script VM's support for external [[Arma Reforger:Script Profiling|Script Profiling]].
Line 891: Line 1,261:
; Example
; Example
  ArmaReforgerSteam.exe -scriptExtProfiler
  ArmaReforgerSteam.exe -scriptExtProfiler
-->
--->


{{GameCategory|armaR|Support}}
{{GameCategory|armaR|Support}}

Latest revision as of 16:14, 23 October 2025

Startup parameters are command line interface(CLI) arguments that go after the executable's name in order to set options; e.g ArmaReforgerSteam.exe -window to start the game in windowed mode.

  • Startup parameters' names are case-insensitive - e.g -logstats and -LogSTATS are identical.
  • Spaces in parameter values must be wrapped in quotations - e.g. -addonDownloadDir "E:\Arma Addons"


General

addons

-addons takes a list of mod IDs (specified in their gproj files, without brackets) to be loaded on game start, separated by a comma ,.
Mods are searched in profile/addons, in <executableDir>/addons and in directories specified by -addonsDir (see below).

Mod IDs can be:
  • GUIDs (preferred - found in .gproj)
  • Project ID (found in .gproj)
  • Sub-directory name (fallback solution)
Example
ArmaReforgerSteam.exe -addons 88037E46AD234C72,88037E46AD234C73

addonsDir

-addonsDir specifies additional directories in which the game must look for mods to load, separated by a comma ,.

By default, the game looks into:
  • Documents/My Games/ArmaReforger/profile/addons
  • <executableDir>/addons
It is recommended to use absolute paths to Mod directories even though the provided path can be relative to the executable location.
Example
ArmaReforgerSteam.exe -addonsDir D:\DownloadedMods

addonDownloadDir

-addonDownloadDir specifies where the game and the Workshop should download addons. Downloaded addons will be stored in addons subfolder inside of target directory.

It is recommended to use absolute paths to Mod directories even though the provided path can be relative to the executable location.
It is not necessary to combine this command with addonsDir parameter.
Example
ArmaReforgerSteam.exe -addonDownloadDir D:\DownloadedMods

addonTempDir

-addonTempDir specifies the directory for temporary content. The default temporary directory is:

  • before armareforger-symbol black.png 1.4.0: %localappdata%/Temp/<addon>/<temp data> on Windows or /tmp/<addon>/<temp data> on Linux
  • since armareforger-symbol black.png 1.4.0: <addonsDir>/<addon>/temp/<temp data>
Example
ArmaReforgerSteam.exe -addonTempDir "C:\Temp"

backendDisableStorage

-backendDisableStorage disables use of storage, no loads or saves can be performed both online and local.

Example
ArmaReforgerSteam.exe -backendDisableStorage

backendFreshSession

-backendFreshSession skips the initial load request from dedicated server's configuration file or from script - the DS Session basically starts as a brand new one, the rest of functionalities is not affected (saves, runtime loads, etc).

Example
ArmaReforgerSteam.exe -backendFreshSession

backendLocalStorage

-backendLocalStorage forces Save & Load of player and general data normally sent to/received from the backend to work with local JSON files in profile folder instead.

Example
ArmaReforgerSteam.exe -backendLocalStorage

freezeCheck

number value, range 0..600, default 300

-freezeCheck overrides time in seconds to forcefully crash on application freeze or completely disable detection.

Workbench has default time set to 1 minute and will only generate minidump without crashing.
Example
ArmaReforgerSteam.exe -freezeCheck 30

freezeCheckMode

string value, default minidump (workbench) or crash

-freezeCheckMode overrides behavior which should happen when freeze is detected.

  • crash - force crashes the application
  • minidump - silently generates minidump and keeps application running until it unfreezes or is terminated by user
  • armareforger-symbol black.png 1.3.0 kill - will force kill the application - is more reliable than {hl|crash} but does not provide any data about the freeze
Option minidump is supported only on Windows.
Example
ArmaReforgerSteam.exe -freezeCheckMode crash
ArmaReforgerSteam.exe -freezeCheckMode minidump

cfg

-cfg forces to load specific user engine settings config (things like graphics settings, window position and size etc).

GPUAdapter

-GPUAdapter forces to use the graphic card at the provided index. GPU index can be found using DxDiag.

Example
ArmaReforgerSteam.exe -GPUAdapter 0

language

-language sets the game language by language code - supported language codes depends on StringTable which is set in gproj. Arma Reforger supported languages are:

  • flag uk.gif en_us - English
  • flag france.gif fr_fr - French
  • flag italy.gif it_it - Italian
  • flag germany.gif de_de - German
  • flag spain.gif es_es - Spanish
  • flag czechrep.gif cs_cz - Czech
  • flag poland.gif pl_pl - Polish
  • flag russia.gif ru_ru - Russian
  • flag japan.gif ja_jp - Japanese
  • flag korea.gif ko_kr - Korean
  • flag portugal.gif pt_br - Portuguese
  • flag china.gif zh_cn - Mandarin
  • armareforger-symbol black.png 1.2.0 flag ukraine.gif uk_ua - Ukrainian
Example
ArmaReforgerSteam.exe -language cs_cz

noBackend

-noBackend disables backend-related http communication.

Example
ArmaReforgerSteam.exe -noBackend

noSound

-noSound disables the sound system processing.

Example
ArmaReforgerSteam.exe -noSound

noSplash

-noSplash skips splash screens on game load.

Example
ArmaReforgerSteam.exe -noSplash

noThrow

-noThrow disables all kinds of error message dialogs. (VMEs, asserts, crashes, ...).

Example
ArmaReforgerSteam.exe -noThrow

profile

-profile defines the path to the profile directory to be used, either by parent directory name or by path.

Example
ArmaReforgerSteam.exe -profile "David Armstrong"								// targets %userprofile%\My Documents\My Games\David Armstrong\profile
ArmaReforgerSteam.exe -profile "C:\Users\MyUserName\Documents\ArmaReforgerDir"	// targets "C:\Users\MyUserName\Documents\ArmaReforgerDir\profile"

singleThreadedUpdate

-singleThreadedUpdate disables multithreaded update.

Example
ArmaReforgerSteam.exe -singleThreadedUpdate

world

-world defines the world file to be loaded on startup, both absolute and relative paths are supported although it is recommended to use path relative to created filesystems (eg. worlds/myworld.ent). Workbench ignores this parameter - for that, use -load parameter instead.

Example
ArmaReforgerSteam.exe -world worlds/myworld.ent


Window

window

-window starts the game windowed (fullscreen by default).

Example
ArmaReforgerSteam.exe -window

posX

posY

-posX and -posY define the initial window position. They must be used with -window.
posX 0 is left of the screen,
posY 0 is top of the screen.

Example
ArmaReforgerSteam.exe -window -posX 0 -posY 64

screenWidth

screenHeight

-screenWidth and -screenHeight define the window's size (and not its render resolution). They must be used with -window.

Example
ArmaReforgerSteam.exe -window -screenWidth 1024 -screenHeight 578

forceUpdate

-forceUpdate forces the application to render and update even when the window is out of focus.

Previously known as -noPause in earlier titles.
Example
ArmaReforgerSteam.exe -forceUpdate

noFocus

-noFocus prevents window focus stealing on game initialization.

Example
ArmaReforgerSteam.exe -noFocus


Workbench

These parameters apply to the Workbench executable.

forceSettings

-forcesettings forces to use the specified Workbench settings from a file instead of the usual settings stored in Windows registry which will be entirely ignored. The settings in a file will be used for reading and also writing. This functionality is compatible with wbSettingsDump.ini files being attached to crash reports.

It is possible to export Workbench settings to an .ini file from Workbench options.

gproj

-gproj defines the addon project to be loaded - it can be used to skip the Workbench's addon selection screen.

Example
ArmaReforgerWorkbenchSteamDiag.exe -gproj "C:\Program Files (x86)\Steam\steamapps\common\Arma Reforger\addons\data\ArmaReforger.gproj"

gprojConfig

-gprojConfig forces loading the provided configuration e.g PC, HEADLESS etc.

Example
ArmaReforgerWorkbenchSteamDiag.exe -gprojConfig PC

wbModule

-wbModule specifies which Workbench module must be launched (with -run):

Editor Entry (case-insensitive) Additional Information
Resource Manager resourceManager
World Editor worldEditor See also Workbench - WorldEditor Module below
Particle Editor particleEditor
Animation Editor animEditor
Script Editor scriptEditor See also Workbench - ScriptEditor Module below
Audio Editor audioEditor
Behavior Editor behaviorEditor
Procedural Animation Editor procAnimEditor
String Editor localizationEditor See also Workbench - LocalizationEditor Module below
Navmesh Generator navmeshGeneratorMain See also Workbench - NavmeshGeneratorMain Module below
  • -wbmodule requires an equal sign = to work.
  • Parameters specified after the module name are considered to be parameters to the module specifically.
  • The -run parameter must be added after each instance of -wbModule for them to launch.
Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run

plugin

-plugin specifies which Workbench plugin must be launched (WorldTestPlugin, TextureImportTool, MaterialImportTool, WorldDataExport etc).

  • Parameters specified after the plugin are considered to be parameters to the plugin specifically.
  • Plugins are loaded for specific modules. Before loading a plugin specify the appropriate wbModule.
Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -plugin=ResavePlugin pluginArguments

run

-run tells the executable to open the designated Workbench module (specified by -wbModule usage).

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run

load

-load tells the executable to open selected file in the designated Workbench module (specified by -wbModule usage). The file path can be specified either by absolute path, relative path, exact path or by resource name.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "world/myworld.ent"

This will open up the World Editor and load the myworld.ent file.

packAddon

-packAddon is the main parameter used for addon packing.

When no directory is specified (by using packAddonDir), the directory from the last session is used.

When packing an addon for the first time, a new directory is automatically created in the same dir as profile.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -packAddon

packAddonDir

-packAddonDirspecifies the output directory where resulting PAKs will be saved.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -packAddon -packAddonDir "D:\build\Green"

publishAddon

-publishAddon is main parameter used for addon publishing.

It should be used only for publishing addon updates, and not for the initial publish because data from last session are used to fill in the blanks.

It can be used on its own, in combination with packAddon or in combination with parameters starting with "publishAddon".

When no directory is specified (by using publishAddonDir) a directory from last session is used.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon

publishAddonDir

-publishAddonDir specifies the pre-packed data directory (obtained by the -packAddon parameter above). When not specified, directory from the last session is used.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon -publishAddonDir "D:\build\Green"

publishAddonVersion

-publishAddonVersion specifies the mod's version number. When not specified, newest version found on back-end is used and it's last digit is automatically incremented.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -publishAddon -publishAddonVersion "2.3.5"

publishAddonChangeNote

-publishAddonChangeNote is an optional parameter that specifies a note to the provided update.

Example
ArmaReforgerWorkbenchSteamDiag.exe -publishAddonChangeNote "Fix shading"

publishAddonChangeNoteFile

-publishAddonChangeNoteFile is an optional parameter which is used to specify this update's change note.

Example
ArmaReforgerWorkbenchSteamDiag.exe -publishAddonChangeNoteFile "C:\Addon\changelog.txt"

publishAddonPreviewImage

-publishAddonPreviewImage is an optional parameter which you can use to specify the preview image file's path.

Example
ArmaReforgerWorkbenchSteamDiag.exe -publishAddonPreviewImage "z:/mymod/my_preview_image.jpg"

publishAddonScreenshots

-publishAddonScreenshots is an optional parameter that specifies the directory from where the screenshots should be taken. It is then automatically scanned for all valid image file types (jpg, png, bmp).

Example
ArmaReforgerWorkbenchSteamDiag.exe -publishAddonScreenshots "Z:/mymod/screenshots"

rebuild-database-only

-rebuild-database-only makes Workbench automatically exit when the database file is refreshed. This is useful for creating game packages which should be distributed with the latest database file.

Example
ArmaReforgerWorkbenchSteamDiag.exe -rebuild-database-only

scrDefine

-scrDefine allows to determine a script preprocessor definition. Multiple ones can be chained using multiple -scrDefine.

This parameter also works for Client and Server executables.

#ifdef TAG_DEBUG Print("The TAG_DEBUG flag is defined."); #else Print("The TAG_DEBUG flag is not defined."); #endif

Example
ArmaReforgerWorkbenchSteamDiag.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
ArmaReforgerSteam.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG
ArmaReforgerServer.exe -scrDefine TAG_DEBUG -scrDefine OTHER_FLAG

scrNoInline

This parameter only works on diag exe!

-scrNoInline disables inline optimisation for debug purposes.

Example
ArmaReforgerSteamDiag.exe -scrNoInline

wbBackendLogin

-wbBackendLogin enforces a specific account to log in. Password is hidden console log.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbBackendLogin [email protected] myPassword

noGameScriptsOnInit

-noGameScriptsOnInit skips game scripts compilation on Workbench initialisation. This results in a faster startup but with the need to recompile scripts before using any script-dependent elements (prefabs, configs, etc).

Game scripts can be compiled in Script Editor using F7.
Example
ArmaReforgerWorkbenchSteamDiag.exe -noGameScriptsOnInit

enableWARP

-enableWARP allows DirectX WARP (Windows Advanced Rasterization Platform) to create a virtual device for computers without a DirectX 12 device.

This parameter does not force WARP, only allows it.
Example
ArmaReforgerWorkbenchSteamDiag.exe -enableWARP

clearSettings

-clearSettings, as its name suggests, clears all Workbench user preference - window positions, preview settings, last opened files etc.

Example
ArmaReforgerWorkbenchSteamDiag.exe -clearSettings

exitAfterInit

-exitAfterInit makes Workbench automatically exit once it is completely initialised and all startup parameters are executed.

Example
ArmaReforgerWorkbenchSteamDiag.exe -exitAfterInit

diagMenu

-diagMenu overrides where diagnostic menu saved settings are stored (see hints section of Arma Reforger:Diag Menu ).

Example
ArmaReforgerWorkbenchSteamDiag.exe -diagMenu "file.txt"


Workbench - AnimationEditor Module

animDebugger

This parameter only works on diag exe!

-animDebugger enables animation debugging.

Example
ArmaReforgerWorkbenchSteamDiag.exe -animDebugger


Workbench - LocalizationEditor Module

build

-build creates runtime string tables from the opened string table.

Example
-wbModule=LocalizationEditor -run -load {C014582791ECBF24}Language/localization.st -build -saveDir C:\tmp\

For building also hidden items from the localisation database, use -scrDefine LOCALIZATION_BUILD_HIDDEN:

ArmaReforgerWorkbenchSteamDiag.exe -scrDefine LOCALIZATION_BUILD_HIDDEN -wbModule=LocalizationEditor -run -load {C014582791ECBF24}Language/localization.st -build -saveDir C:\tmp\

saveDir

-saveDir specifies the (absolute) save directory for the module's build command.

Example
see above


Workbench - NavmeshGeneratorMain Module

autogenerate

-autogenerate generates the provided world's navmesh.

Example
// This opens up the World Editor with myworld.ent loaded, connects Navmesh Editor to it and starts navmesh generation of the specified navmesh projects.
// Navmesh Editor generates the navmesh and saves it to the path originally held by NavmeshWorldEntity in the world.
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=NavmeshGeneratorMain -run -autogenerate "world/myworld.ent"

navmesh projects are optional and can be ALL to generate all projects.

saveDir

-saveDir is an optional parameter that defines in which directory the data will be exported.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=NavmeshGeneratorMain -run -autogenerate "world/myworld.ent" -saveDir "C:/temp/output/"

logNavmeshGen

-logNavmeshGen logs output from changing states of the navmesh generator state machine.

This parameter does nothing at the moment as it is always enabled.


Workbench - ResourceManager Module

buildData

-buildData builds all data of one addon in a specified directory. Without addon specification, it builds data of the current addon (usually a game). There are two mandatory parameters: PlatformName and TargetFolder. The third parameter, AddonName, is not mandatory.

Example 1
This builds data of a current addon
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -builddata PC "C:\Data\PCData"
Example 2
This builds data of a specific addon called "ArmaReforger"
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -builddata PC "C:\Data\PCData" ArmaReforger

This will build PC data to the provided directory. Possible options for the platform name are PC, PC_WB, XBOX_ONE, XBOX_SERIES, PS4, HEADLESS.

Resource database cache file resourceDatabase.rdb is being saved after build too. It contains only the files which are part of the build.

State of the incremental build progress is being continuously saved every 60 seconds into LastBuildInfo.binfo file. After an unexpected crash, the next build will continue from this last saved state.

Note that entire workbench application will be exited when build is completed.

metaFiles

-metaFiles is an optional parameter which may be used together with -buildData - it copies .meta files to the built data.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=ResourceManager -buildData PC "C:\Data\PCData" -metaFiles

loadBuiltData

-loadBuiltData is an optional parameter which may be used together with -buildData - built resource is loaded into memory and possible errors are printed into the log. Useful for identifying broken resources.

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData PC "C:\Data\PCData" -metaFiles -loadBuiltData

includeTypes

-includeTypes is an optional parameter which may be used together with -buildData - it specifies a list of file types (separated by a comma) that will be included in data build. Can be combined together with -excludeTypes

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -builddata PC "c:\Data\PCData" -metaFiles -includeTypes "edds,xob,emat"

excludeTypes

-excludeTypes is an optional parameter which may be used together with -buildData - it specifies a list of file types (separated by a comma) that will not be included in data build. Can be combined together with -includeTypes

Example
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -builddata PC "C:\Data\PCData" -metaFiles -excludeTypes "nmn,ent,terr"

filterPath

-filterPath is an optional parameter which may be used together with -buildData - it allows to limit data build to only a single folder or file.

Example 1
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData -filterPath "c:\Data\ArmaReforger\worlds\Arland"

This limits that only data from this specific folder will go to data build

Example 2
ArmaReforgerWorkbenchSteamDiag.exe -wbmodule=ResourceManager -buildData -filterPath "c:\Data\ArmaReforger\worlds\Arland\Arland.ent"

This limits that only data that belong to Arland.ent will go to data build (ent, smap, smd, ...)

filterTags

-filterTags is an optional parameter which may be used together with -buildData - it can be used to exclude/include particular files and folders from/to data build. It is based on tagging files and folders through the "Build Tags" property which is part of file/folder import settings. This parameter has a form of a C++ expression where can be used only string tags and these three operators:

  • & - logical AND
  • | - logical OR
  • ! - logical NOT
Examples
ArmaReforgerWorkbenchSteamDiag.exe -filterTags "!wbOnly & !testOnly & !consolesOnly"

This includes to build everything except files and folders tagged as wbOnly or testOnly or consolesOnly

ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly"

This includes to build only files and folders tagged as wbOnly

ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly & !testOnly"

This includes to build only files and folders tagged as wbOnly but without those of them that are tagged as testOnly

ArmaReforgerWorkbenchSteamDiag.exe -filterTags "wbOnly | testOnly"

This includes to build only files and folders tagged as wbOnly or testOnly

ArmaReforgerWorkbenchSteamDiag.exe -filterTags "(!wbOnly & !testOnly) | alwaysIncluded"

This includes to build everything except files and folders tagged as wbOnly or testOnly. If some file or folder is tagged with alwaysIncluded it will be included even though it's located inside a wbOnly folder for example

wbSilent

-wbsilent initialises the engine, workbench modules and exit without opening any windows; it can be used to validate engine/game initialisation and script compilation.


Workbench - ScriptEditor Module

validate

string value, default ALL

-validate checks if the game scripts are compilable and returns Workbench application return code of "-1" when compilation failed and "0" when compilation was successful. Value is optional and script configuration name is expected (Configurations can be found in project settings, it is usually PC, XBOX_SERIES, etc).


Workbench - WorldEditor Module

forceSaveAll

-forceSaveAll

  • Normal edit mode: re-saves all entity layers of opened map (.ent file + its .layer files) and also all prefabs and configs that are used in the opened map.
  • Prefab edit mode: re-saves only opened prefab and also all other prefabs and configs that are used in the opened prefab.
Example 1 (normal edit mode)
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "world/myworld.ent" -forceSaveAll
Example 2 (prefab edit mode)
ArmaReforgerWorkbenchSteamDiag.exe -wbModule=WorldEditor -run -load "Prefabs/Structures/Houses/Villa/Villa_E_2I01/Villa_E_2I01.et" -forceSaveAll


Hosting

These parameters apply to the Server executable.

a2sIpAddress

-a2sIpAddress sets Steam Query Protocol's Bind IP address.

Example
ArmaReforgerServer.exe -a2sIpAddress 192.168.1.10

a2sPort

-a2sPort sets Steam Query Protocol's Bind port.

Example
ArmaReforgerServer.exe -a2sPort 7777

autoreload

-autoreload reloads the scenario when the session ends after the provided delay, without shutting down the server. Value is in seconds.

armareforger-symbol black.png 1.3.0 the disabled value makes the server restart and relaunch as the same instance.

Example
ArmaReforgerServer.exe -autoreload 10

autoshutdown

-autoshutdown ensures the correct server shutdown process.

To give 30 seconds post game and then shutdown:

Example
ArmaReforgerServer.exe -autoreload 30 -autoshutdown
To circumvent 1.3.0's server restart issue, make sure to use this command and configure the server to automatically restart on failure or shutdown.

bindIP

-bindIP can be used to override both gameHostBindAddress and gameHostRegisterBindAddress values present in server config.

Example
ArmaReforgerServer.exe -bindIP 192.168.1.42

bindPort

-bindPort can be used to override both gameHostBindPort and gameHostRegisterBindPort values present in server config.

Example
ArmaReforgerServer.exe -bindPort 2302

config

-config is used by servers to point to a JSON server configuration.

See Server Hosting for more information.
Example
ArmaReforgerServer.exe -config myConfigFile.json

forceDisableNightGrain

-forceDisableNightGrain disables night grain in multiplayer.

Single player already disables night grain.
Example
ArmaReforgerServer.exe -forceDisableNightGrain

listScenarios

-listScenarios prints to game logs the scenario .conf file paths.

  • Workshop scenarios will only be listed if no scenario is being loaded (through e.g a config).
  • A list of official scenarios can be found on Server Config - scenarioId.
Example
ArmaReforgerServer.exe -listScenarios

loadSessionSave

-loadSessionSave allows the game to load a previous game session.

It can be used alone to load the latest save, or with a specific save file name. When left empty, it will attempt to locate the latest save game data for the current scenario on launch. Optionally, as a parameter, the UUID of a specific save can be passed, which is found inside each save point's meta-info.json file.

Examples
ArmaReforgerSteam.exe -loadSessionSave
ArmaReforgerSteam.exe -loadSessionSave 07e8fa26-d5b6-47f6-a19b-641c72ab05bc
ArmaReforgerServer.exe -loadSessionSave
ArmaReforgerServer.exe -loadSessionSave 0d51b792-2a66-47d2-b71a-09086cffba3a

keepSessionSave

-keepSessionSave keeps any save data for completed playthroughs on the game's end screen.

Example
ArmaReforgerSteam.exe -keepSessionSave

logStats

-logStats allows to log performance statistics every (optionally) defined interval (in milliseconds).

Example
ArmaReforgerServer.exe -logStats - logs every seconds
ArmaReforgerServer.exe -logStats 10000 - only logs every 10s
Result
FPS: 60.0, frame time (avg: 16.7 ms, min: 9.3 ms, max: 23.7 ms), Mem: 3291106 kB, Player: 2, AI: 104, Veh: 0 (17), Proj (S: 12, M: 0, G: 0 | 12), RplItemsS: 410, RplItemsC0: 17068
  • FPS: <float> = Current server FPS value
  • frame time (avg: <float> ms, min: <float> ms, max: <float> ms) = The average, minimum, & maximum server frame times
  • Mem: <int> = The current memory usage in kilobytes as reported internally by the server
  • Player: <int> = Number of current players
  • AI: <int> = Number of current AI spawned on the server
  • Veh <int> (<int>) = The value inside the parentheses is the current number of vehicles spawned on the server
  • Proj:
    • S: <int> = Number of active shells
    • M: <int> = Number of active missiles
    • G: <int> = Number of active grenades
    • | <int> = Total projectiles
  • RplItemsS: <int> = The number of dynamic (spawned during game) streams on the server
  • RplItemsC0: <int> = The number of streams open to the client
The memory usage reported by -logStats is a server approximation and is therefore not 100% accurate when compared with the operating system values.

logVoting

-logVoting adds logging info to the voting system with information about who created, voted, and against whom the vote was created.

Example
ArmaReforgerServer.exe -logVoting

maxFPS

-maxFPS sets max FPS limit - useful for a server, or to force a client's max FPS.

Also works on clients, even though the Video Settings FPS limitation option is preferred.
Example
ArmaReforgerServer.exe -maxFPS 30

server

This parameter instructs the executable to launch local server and load selected world. When this parameter is used, config is ignored. Server parameter can be combined with addons & addonsDir parameters to start a server with local mods, which can be useful when testing addon before uploading it Workshop.

ArmaReforgerServer.exe -server "worlds/MP/MPTest.ent" -addonsDir "C:\MyModsDir" -addons MyCustomMod
These parameters apply to the Game executable.

client

-client starts up an RplSession in local client mode. The session tries to connect to the provided IP.

Example #1
ArmaReforgerSteam.exe -client 127.0.0.1
Example #2

This will connect the game to a locally hosted dedicated server and load the local MyCustomMod addon:

ArmaReforgerSteam.exe -client -addonsDir "C:\MyModsDir" -addons MyCustomMod

worldSystemsConfig

This parameter only works on diag exe!

-worldSystemsConfig allows setting a world systems config file (of type SystemSettings) when starting a mission directly (not via MissionHeader.conf).

Example
ArmaReforgerSteamDiag.exe -worldSystemsConfig "{C50579A2EC48E8EF}Configs/Systems/MissionSystems.conf"

addonsVerify

This parameter only works on dedicated server!

Verifies the integrity of all installed addons. If any corrupted addons are found, the server will shut down and log the corrupted files. The verification may take some time depending on the size of the addons.

addonsRepair

This parameter only works on dedicated server!

Verifies the integrity of all installed addons. If any corrupted addons are found, they will be repaired automatically. If the repair fails, the server will shut down. The repair duration depends on the addons size and the amount of data which needs to be repaired.


Network Tuning

These parameters apply to the Server executable.

nds

number value, default 2

-nds Network Dynamic Simulation (nds) is a server feature that only streams in relevant replicated entities for each client. The provided value stands for diameter, or the number of cells which are being replicated. To turn the feature off use -nds 0. A higher diameter will result in a bigger networked view range, lower server performance.

Example
ArmaReforgerServer.exe -nds 1

nwkResolution

-nwkResolution defines what resolution Spatial Map cells should be set at in a 100..1000m range. Smaller resolution will result in less "pop-in" but lower networked view range. For high view range use high resolution, but small diameter.

Example
ArmaReforgerServer.exe -nwkResolution 500

rpl-timeout-ms

-rpl-timeout-ms sets the client/server timeout's value, in milliseconds.

Example
ArmaReforgerServer.exe -rpl-timeout-ms 10000

rpl-timeout-disable

This parameter only works on diag exe!

-rpl-timeout-disable disables the client/server timeout.

If a connection stops responding, the server's performance will deteriorate until it eventually runs out of memory and crash. This parameter is strictly for debugging purposes.
Example
ArmaReforgerSteamDiag.exe -rpl-timeout-disable

rpl-reconnect

This parameter only works on diag exe, on client!

The replication tries to reconnect instead of immediately raising connection.

Example
ArmaReforgerSteamDiag.exe -rpl-reconnect

rpl-vcons

number value, range 0..200, default 0

This parameter only works on diag exe!

-rpl-vcons sets the number of virtual connections.

Example
ArmaReforgerSteamDiag.exe -rpl-vcons 5

rpl-validation-rdb-disable

This parameter only works on diag exe!

-rpl-validation-rdb-disable disables the validation of clients resource database.

Make sure you know what you are doing first before disabling the validation as data mismatch may bring undefined behaviour!
Example
ArmaReforgerSteamDiag.exe -rpl-validation-rdb-disable

rpl-validation-scr-disable

This parameter only works on diag exe!

-rpl-validation-scr-disable disables the validation of clients scripts checksum.

Make sure you know what you are doing first before disabling the validation as script mismatch may bring undefined behaviour!
Example
ArmaReforgerSteamDiag.exe -rpl-validation-scr-disable

rpl-validation-version-disable

This parameter only works on diag exe!

-rpl-validation-version-disable disables the validation of clients executable version.

Make sure you know what you are doing first before disabling the validation as version mismatch may bring undefined behaviour!
Example
ArmaReforgerSteamDiag.exe -rpl-validation-version-disable

rpl-validation-devbin-disable

This parameter only works on diag exe!

-rpl-validation-devbin-disable disables the validation of developer binary flag, allowing mixing developer and non-developer binaries in the same multiplayer session.

staggeringBudget

-staggeringBudget defines how many stationary spatial map cells are allowed to be processed in one tick in 1..10201 range. If not set it uses "-nds" diameter. A lower number will limit how many cells the server has to process per tick, but increase the time it takes for a client to have all relevant entities streamed in. If the server experiences significant performance drops on spawning/teleporting then the number is set too high, if the client experiences "pop-in" of replicated items then the number is set too low.

Example
ArmaReforgerServer.exe -staggeringBudget 5000

streamingBudget

-streamingBudget is the global streaming budget that is equally distributed between all connections. To decrement the budget, it uses the replicated hierarchy size of each entity that needs to be streamed in. It cannot go under 100 to prevent the system stalling. A lower number will limit how many entities the server has to process per tick, but increase the time it takes for a client to have that entity streamed in, if the server experiences significant performance drops on spawning/teleporting then the number is set too high, if the client experiences "pop-in" of replicated items then the number is set too low.

Example
ArmaReforgerServer.exe -streamingBudget 500

streamsDelta

number value, range 1..1000, default 100

-streamsDelta is a tool to limit the amount of streams being opened for a client. If the difference between 'the number of streams the server has open' and 'the number of streams the client has open' is larger than the NUMBER then the server will not open any more streams this tick. To be adjusted based on average client networking speed.

Example
ArmaReforgerServer.exe -streamsDelta 200


Debug

AILimit

-aiLimit sets the top limit of AIs. No systems will be able to spawn any AIs when this ceiling is reached (through aiWorld.CanAICharacterBeAdded() - see also SCR_AIGroup and SCR_ChimeraAIAgent).

A value less than or equal to zero simply disables any possible AI.
This parameter applies to both hosted and singleplayer scenarios; while it can save performance, it can also break the experience!
Example
ArmaReforgerServer.exe -AILimit 32
ArmaReforgerServer.exe -AILimit 0
ArmaReforgerSteam.exe -AILimit 100
ArmaReforgerSteam.exe -AILimit 0

AIPartialSim

number value, default: 4

-aiPartialSim sets in how many batches all simulable AIs will divided and processed.
e.g: 150 AIs, 100 simulable AIs (100 in LOD0, 50 in LOD 10), these 100 AIs divided by 4 will make four batches of 25 AIs each.

Example
ArmaReforgerSteam.exe -aiPartialSim 5

autodeployFaction

alias: tdmf

-autodeployFaction overrides respawn faction (e.g US, USSR, FIA etc).

This parameter only works on diag exe!
Example
ArmaReforgerSteamDiag.exe -autodeployFaction US

autodeployLoadout

alias: tdml

This parameter only works on diag exe!

-autodeployLoadout overrides respawn role (using role name from scenario's LoadoutManager).

Example
ArmaReforgerSteamDiag.exe -autodeployLoadout #AR-Role_Driver

createDB

-createDB forces database file's regeneration. Useful after file directories changes, when some resources were moved elsewhere. Takes a few seconds upon start.

Example
ArmaReforgerServer.exe -createDB

debugger

string value, default localhost

-debugger sets the script debugger to a specific address.

Example
ArmaReforgerServer.exe -debugger 192.168.0.5

debuggerPort

number value, default 1000

-debuggerPort sets the script debugger to a specific port.

Example
ArmaReforgerServer.exe -debuggerPort 1040

disableAI

-disableAI disables AIWorld initialisation and ticking.

disableCrashReporter

-disableCrashReporter disables the Crash Reporter from appearing/sending reports automatically.

Example
ArmaReforgerSteam.exe -disableCrashReporter

disableNavmeshStreaming

-disableNavmeshStreaming disables navmesh streaming on all navmesh worlds.

armareforger-symbol black.png 1.2.0 added navmesh projects list support ("BTRlike" for vehicles, "Soldiers" for characters), separated by commas.

Example
ArmaReforgerSteam.exe -disableNavmeshStreaming
ArmaReforgerSteam.exe -disableNavmeshStreaming NAVMESH_PROJECT1,NAVMESHPROJECT2,etc // >= 1.2.0

disableShadersBuild

-disableShadersBuild disables shaders generation.

Example
ArmaReforgerServer.exe -disableShadersBuild

generateShaders

-generateShaders forces shaders generation.

Example
ArmaReforgerServer.exe -generateShaders

rplEncodeAsLongJobs

-rplEncodeAsLongJobs makes replication use long encoding jobs instead of short ones.

Example
ArmaReforgerServer.exe -rplEncodeAsLongJobs

jobsysShortWorkerCount

-jobsysShortWorkerCount sets the number of threads working on short jobs (jobs that must finish in one update loop). Value is limited to the number of CPUs or 16, whichever is the lowest.

Example
ArmaReforgerServer.exe -jobsysShortWorkerCount 4

jobsysLongWorkerCount

number value, range 1..CPUCount, default jobsysShortWorkerCount / 2

-jobsysLongWorkerCount sets the number of threads working on long jobs (jobs that can span multiple iterations of update loop).

Example
ArmaReforgerServer.exe -jobsysLongWorkerCount 4

keepNumOfLogs

number value, default: 10

-keepNumOfLogs sets the maximum amount of logs to keep.

Example
ArmaReforgerServer.exe -keepNumOfLogs 3

log-rdb-checksum

-log-rdb-checksum enables logging detailed information about RDB checksum computation (GUID and path in order in which they are added to checksum) for RDB checksum issues debugging.

Example
ArmaReforgerSteam.exe -log-rdb-checksum

log-scr-checksum

-log-scr-checksum enables the logging of all script files used in compilation and their checksums.

Example
ArmaReforgerSteam.exe -log-scr-checksum

logAppend

-logAppend makes logs to not be emptied on game start, keeping the history.

Example
ArmaReforgerSteam.exe -logAppend

logFS

-logFS logs every F'ile System's read/write operation in filesystem.log. This option is very demanding and can produce a big file in a short time, so it is to be used with caution for debug purpose only.

Example
ArmaReforgerSteam.exe -logFS

logLevel

-logLevel allows for different log levels. Each level includes the ones below it (e.g error includes error and fatal). Possible values range from normal (where everything is logged) to fatal (where only extreme issues are logged):

  • normal
  • warning
  • error
  • fatal
Example
ArmaReforgerSteam.exe -logLevel warning

logTime

string value, default time

-logTime sets log line time's format; can be one of:

  • none
  • time (default)
  • datetime
Example
ArmaReforgerServer.exe -logTime datetime

logsDir

-logsDir defines the directory by name (located in the profile directory) or armareforger-symbol black.png 0.9.8 by path, in which game instance specific data are stored like logs, memory dumps, temporary files etc.

Examples
ArmaReforgerSteam.exe -logsDir "DebugSession1337"								// targets <profileDir>\logs\DebugSession1337
ArmaReforgerSteam.exe -logsDir "C:\Users\MyUserName\Documents\ArmaReforgerDir"	// targets "C:\Users\MyUserName\Documents\ArmaReforgerDir" directly

keepCrashFiles

-keepCrashFiles prevents Crash Reporter from cleaning crash files on successful crash sending.

Example
ArmaReforgerSteam.exe -keepCrashFiles

minidump

-minidump allows minidump generation to include additional data; possible values:

Value Microsoft Equivalent
(see minidump API documentation)
normal MiniDumpNormal
dataSegs MiniDumpWithDataSegs
fullMemory MiniDumpWithFullMemory
Example
ArmaReforgerSteam.exe -minidump fullMemory

scriptAuthorizeAll

-scriptAuthorizeAll disables the security popup about RunCmd, RunProcess, KillProcess and (outside of profile directory) FileIO operations.

Example
ArmaReforgerSteam.exe -scriptAuthorizeAll

silentCrashReport

-silentCrashReport suppresses the Crash Reporter's dialog and automatically sends the report without any user input or message.

Example
ArmaReforgerWorkbenchSteamDiag.exe -silentCrashReport

was noCrashDialog before 1.0.0

VMErrorMode

-VMErrorMode sets script VM's error reporting mode; possible values are:

  • silent - silently continues
  • log_only - logs the error then continues
  • full - shows the VME dialog, logs the error, then clicking "ignore" continues execution
  • fatal - logs the error then exits the game


Profiling

checkInstance

-checkInstance turns on script VM's memory allocations logging - see Script Profiling.

Example
ArmaReforgerSteam.exe -checkInstance