Left 4 Dead 2/Scripting/Director Scripts: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(→‎EMS Stage Specific: Added PanicSpecialsOnly)
m (→‎Spawning limits: MobSpawnSize does override them)
 
(132 intermediate revisions by 21 users not shown)
Line 1: Line 1:
{{LanguageBar}}
{{toc-right}}{{sq}}{{l4d2}} '''Left 4 Dead 2 Director scripts''' are [[L4D2_Vscripts|vscripts]] that are primarily used to influence the behavior of the AI Director. They are extensively used for custom finales and gauntlet events.  
{{toc-right}}{{sq}}{{l4d2}} '''Left 4 Dead 2 Director scripts''' are [[L4D2_Vscripts|vscripts]] that are primarily used to influence the behavior of the AI Director. They are extensively used for custom finales and gauntlet events.  
== Usage ==
== Usage ==
Director scripts typically contain a table named [[#DirectorOptions|''DirectorOptions'']], which contains variables that change up the decision making of the Director. They can be ran / stopped with the following inputs to the {{ent|info_director}} entity:
{{I|BeginScript|Run Director scripts, and parse their DirectorOptions table once. If a Director script is already running and this input is called, the previous Director script automatically stops running.|param=scriptlist}}
{{I|EndScript|Ends the running script and resets the Director options to either the map's DirectorOptions values, or the default settings.}}
{{I|ScriptedPanicEvent|With the script names given they'll be ran as a scripted panic event, which is like a mini finale, so a script should be structured as a finale script.|param=scriptlist}}


Director scripts are executed with inputs to the [[info_director]] entity. A [[#DirectorOptions|<code>DirectorOptions</code>]] table is used to give new temporary values for the variables the director uses for decision making. Additional commands can be accessed through the [[List_of_L4D2_Script_Functions#CDirector|<code>Director</code>]] object. Only one Director script can be running at a time.
{{note|Scripts used with these inputs will not work if they are in a subdirectory under the<code>vscripts</code>folder, even though you can use subdirectories in other script contexts. Events will play out only the 1 second DELAY "stage 0" if they violate this.}}
 
=== Inputs ===
;<code>BeginScript <''script name''></code>
:Executes a generic Director script, for example for onslaught events or changing spawning behavior.
;<code>EndScript</code>
:Ends the running script and resets the Director options to the map specific values.
;<code>BeginScriptedPanicEvent <''script name''></code>
:Begins a Scripted Panic Event.
 
{{note|Scripts used with <code>BeginScriptedPanicEvent</code> will not work if they are in a subdirectory, even though you can use subdirectories in other script contexts. They must reside under the vscripts folder, or they will simply act as a 1 stage 1 second delay.}}


There is also a [[Left 4 Dead 2/Scripting/Script Functions#CDirector|''CDirector'']] object for VScripts, and its extra functions can be paired for customizing your Director scripts.


== General scripts and Onslaughts ==
== General scripts and Onslaughts ==
Line 22: Line 18:


<code>c2m4_barns_onslaught.nut</code> (with annotations):
<code>c2m4_barns_onslaught.nut</code> (with annotations):
{{ScrollBox|<source lang=cpp>
{{ScrollBox|<source lang=js>
Msg("Initiating Onslaught\n");
Msg("Initiating Onslaught\n");


Line 65: Line 61:
Director.PlayMegaMobWarningSounds() // Plays the incoming mob sound effect.
Director.PlayMegaMobWarningSounds() // Plays the incoming mob sound effect.
</source>}}
</source>}}


== Finales and Scripted Panic Events ==
== Finales and Scripted Panic Events ==
Finales and Scripted Panic Events consist of a number of different kind of stages set in <code>DirectorOptions</code>.
The structure of custom finales and scripted panic events (or mini-finales) setup their structure with a script. In the script, its <code>DirectorOptions</code> table defines:
{{ExpandBox|
* Total wave count
* Type of each wave, and a value
* Optional alternative waves
}}


The Director script for the finale is always loaded from <code><''map name''>_finale.nut</code>. Scripted panic events are launched from the [[info_director]] <code>BeginScriptedPanicEvent</code> input.  
To load a custom finale script, nothing extra needs to be done other than naming the script as <code>[current map]_finale.nut</code>. The script will be automatically loaded when the custom finale starts.


However, scripted panic events are different; they are always manual, and initiated by inputting <code>ScriptedPanicEvent [scriptfilename]</code> to {{ent|info_director}} without file extensions nor parent folders.
{{bug|hidetested=1|In Scripted Panic Events:
*Sending an <code>EndCustomScriptedStage</code> input or running <code>Director.ForceNextStage()</code> during a <code>SCRIPTED</code> stage ends the whole event.
*When the last stage ends, its repeated once more but with the default values. Effects are as follows: {{ExpandBox|noendlinebreak=1|
:*PANIC and TANK stages will repeat with only 1x Wave / Tank.
:*DELAY and SCRIPTED stages repeat, but are then skipped immediately.
}}{{note|The repeating bug can be circumvented by using the <code>ONSLAUGHT</code>/<code>SCRIPTED</code> stage to call another director script which ends the event via an <code>EndCustomScriptedStage</code> input to the info_director entity.}} |only=l4d2}}


A stage can be one of 4 types (other values will break the finale and go right to ESCAPE):
*PANIC - A panic event, the value is the number of waves of infected.
*TANK - Spawn a tank(s), the value is the number of tanks to spawn.
*DELAY - A delay, the value is the number of seconds to wait before proceeding to the next stage.
*SCRIPTED (also called ONSLAUGHT) - The value should be the name of a VScript to call or "" (which will do nothing), any bad value here will crash you to the desktop. Your script is responsible for sending an <code>EndCustomScriptedStage</code> input to the director (a goal of your choice, like a certain trigger volume, timer, random value, etc.). [[trigger_finale]] input <code>AdvanceFinaleState</code> may also work. Otherwise, the '''onslaught will not end.'''


=== Setting up Stages ===
There are 4 main types of stages (visit [[L4D2_EMS/StageTypeAppendix|StageTypeAppendix]] for others):
{| class="standard-table" style="width: 80%;"
! Name
! Value
! Description
|-
| PANIC || 0 || A panic event; The value is the number of infected waves.
|-
| TANK  || 1 || Spawn tank(s), with the value as the number of tanks to spawn.
|-
| DELAY || 2 || A delay, its value is the number of seconds to wait before it goes to the next stage.
|-
| SCRIPTED || 3 || Sometimes with the <code>ONSLAUGHT</code>name; sets up a stage using the loaded script's contents. The value is the name of the relevant VScript (with no file extension).
In <code>SCRIPTED</code>, the script '''is fully responsible''' for dictating when it'll end! To end the stage, send the <code>EndCustomScriptedStage</code> input to a {{ent|info_director}} entity. Moreover on finales, these two can be used instead:
{{ExpandBox|noendlinebreak=1|
* <code>AdvanceFinaleState</code> input for {{ent|trigger_finale}} entity.
* Using the [[#Finale_Specific.2FRelated|<code>MinimumStageTime</code>]] DirectorOptions key.
}}
|}


An example custom finale script:
=== Code Sample ===
{{ScrollBox|<source lang=cpp>
An example custom finale script, that also makes use of various finale settings documented at later parts of this page:
ERROR <- -1
<!-- Making this an ExpandBox seems weird -->
PANIC <- 0
{{ScrollBox|<syntaxhighlight lang=js>
TANK <- 1
const ERROR = -1
DELAY <- 2
const PANIC = 0
SCRIPTED <- 3  
const TANK = 1
const DELAY = 2
const SCRIPTED = 3  


DirectorOptions <-
DirectorOptions <-
{
{
//-----------------------------------------------------
//-----------------------------------------------------
A_CustomFinale_StageCount = 8 // Number of stages. Used for calculating the Versus score.
A_CustomFinale_StageCount = 3 // Number of stages. Used for calculating the Versus score.
B_CustomFinale_StageCount = 3 // Number of stages for the alternate B finale type
A_CustomFinale1 = PANIC
A_CustomFinaleValue1 = 2   // Two panic waves.
A_CustomFinale1 = PANIC
A_CustomFinaleValue1 = 2 // Two panic waves.
A_CustomFinale2 = DELAY
A_CustomFinaleValue2 = 12  // Delay for twelve seconds in addition to stage delay.
A_CustomFinale2 = DELAY
A_CustomFinaleValue2 = 5 // Delay for five seconds in addition to stage delay.
A_CustomFinale3 = TANK
A_CustomFinaleValue3 = 3 // 3 tanks!
A_CustomFinale3 = TANK
A_CustomFinaleValue3 = 3 // 3 tanks! Start rescue for Finale Type A after this wave ends too.
A_CustomFinale4 = DELAY
A_CustomFinaleValue4 = 12 // Wait some more.
B_CustomFinale1 = SCRIPTED
B_CustomFinaleValue1 = "my_scripted_stage" // Start of with running a custom scripted stage using a separate script.
A_CustomFinale5 = SCRIPTED
A_CustomFinaleValue5 = "my_scripted_stage.nut" // Run a custom scripted stage using a separate script.
B_CustomFinale2 = TANK
B_CustomFinaleValue2 = 1 // Follow up with a single tank.
A_CustomFinale6 = DELAY
A_CustomFinaleValue6 = 15 // Wait 15 seconds.
A_CustomFinale7 = TANK
A_CustomFinaleValue7 = 1 // One more tank.
 
A_CustomFinale8 = DELAY
A_CustomFinaleValue8 = 10 // Wait ten seconds ... rescue!


B_CustomFinale3 = DELAY
B_CustomFinaleValue3 = 5 // Wait five more seconds ... rescue for Finale Type B!


//-----------------------------------------------------
//-----------------------------------------------------


CommonLimit = 10
CommonLimit = 10
SpecialRespawnInterval = 25
SpecialRespawnInterval = 25
}
}


function OnBeginCustomFinaleStage( num, type ) // This function is run at the beginning of every stage.
function OnBeginCustomFinaleStage( num, type ) // This function is run at the beginning of every stage.
{
{
      printl( "Beginning custom finale stage " + num + " of type " + type );
printl( "Beginning custom finale stage #" + num + " of type: " + type )
      MapScript.DirectorOptions.CommonLimit <- num * 10 // Increase commons by 10 linearly with stages.
if( DirectorOptions.CommonLimit < 30 )
}</source>}}
DirectorOptions.CommonLimit = num * 5 // Increase commons by 5 linearly with stages.
 
}
</syntaxhighlight>}}
See a list of all official finale scripts [[L4D2_Level_Design/Custom_Finale|here]].


== Adaptive Dramatic Pacing ==
== Adaptive Dramatic Pacing ==
{{todo|Add info from [http://www.valvesoftware.com/publications/2009/ai_systems_of_l4d_mike_booth.pdf]}}
{{todo|Add info from [https://web.archive.org/web/20120505233022/https://www.valvesoftware.com/publications/2009/ai_systems_of_l4d_mike_booth.pdf]}}
 


== Callbacks ==
== Callbacks ==
When functions with these specific names are placed in a Director script scope table (see [[L4D2 Vscripts#Delegation|delegation rules]]), they get called by C++ with specific arguments used.


*'''<code>void Update()</code>'''
=== <code>LocalScript</code> based callbacks ===
:If you define an <code>Update()</code> function in your Director Script, it will run repeatedly much like a <code>Think()</code> function, but ONLY a finale via [[trigger_finale]] is triggered, if you have multiple scripts that are running that define it, they all will be called. The use of Update() is also found in the Bleed Out mutation (mutation3.nut), but needs further testing to see see if it behaves the same way like during a finale.
*'''<code>float GetCustomScriptedStageProgress(float ''defvalue'')</code>'''
 
:Will be called during FINALE_CUSTOM_SCRIPTED stages. The function should return a value from 0-1 to indicate the completion percentage of the stage. The default time-based completion percentage is passed in as a parameter.
=== Finale Script specific ===


*'''<code>void OnBeginCustomFinaleStage(int ''num'', int ''type'')</code>'''
*'''<code>void OnBeginCustomFinaleStage(int ''num'', int ''type'')</code>'''
:If defined, will be called on every stage change with the number, and type, this is how you would change director options between stages (spawn directions, etc). <code>num</code> refers to the finale stage number passed by the director and <code>type</code> is the stage type (PANIC, TANK, etc.).
:Will be called on every scripted panic event or finale stage change. This is how you would change director options between stages (spawn directions, etc). <code>num</code> refers to the finale stage number passed by the director and <code>type</code> is the stage type (PANIC, TANK, etc.) following the standard, <code>STAGE_</code> prefixed, enumeration.
 
:{{bug|hidetested=1|The [[Left 4 Dead 2/Scripting/Script Functions#CEntities|''CEntities'']] object will not work properly in this callback, always returning the default value ''null'' every tick until Squirrel terminates the script.|only=l4d2}}
*'''<code>function OnChangeFinaleMusic()</code>'''
:{{todo|confirm category/working}}
 


=== <code>ChallengeScript</code> based callbacks ===
*'''<code>void GetNextStage()</code>'''
:Called by the director when it wants a new stage. It can be forced with <code>Director.ForceNextStage()</code>. Used by [[L4D2 Decrypted mutations#Dash|Dash]], [[L4D2 Decrypted mutations#Holdout|Holdout]] and [[L4D2 Decrypted mutations#Tank Run|Tank Run]].


== DirectorOptions ==
== DirectorOptions ==
The <code>DirectorOptions</code> table is used for overriding various Director variables that govern among other things, infected spawning, finale stages and more.
The<code>DirectorOptions</code>table is used for overriding various Director variables that govern among other things: infected spawning rough distance, finale stages, and others.


{{note|In mode and map scripts, use the SessionOptions table to influence the director instead, or the MutationOptions/MapOptions tables for initial values. The DirectorOptions table can get overwritten or cleared by map events, and writing a new DirectorOptions on a finale will erase the finale script.}}
In mode and map scripts, use SessionOptions and MutationOptions/MapOptions! SessionOptions for influencing the director, while the MutationOptions/MapOptions tables for setting default values. This is because BaseScriptedDOTable has priority and overrides some initial parameters in the DirectorOptions table of the mode script scope (see MergeSessionOptionTables in [[scriptedmode.nut]]).
{{note|'Mode scripts' term refer to scripts ran when a specific gamemode is active, like <code>shootzones.nut</code>. 'Map scripts' on the other hand, could run anytime during a map, dependent of map logic. Examples for this include: <code>c3m1_plankcountry_holdout.nut</code>,<code>c9m1_minifinale.nut</code> and <code>c11m4_reserved_wanderers.nut</code>.}}


Though, while customizing the Director's behaviour, you might come across these issues:<br>


<u>'''The Fields interact a lot!'''</u><br>
Say you have a custom mutation mod, and you use a<code>DirectorOptions</code>table to influence the Director. It reduces<code>CommonLimit</code> for lesser Commons, but also reduces both<code>MobSpawnTimeMin</code>and<code>MobSpawnTimeMax</code> to make them respawn faster. However, when playtesting your mod on Dead Center, everything seems to revert to default after you complete the Gauntlet fetch quest, featuring [[weapon_cola_bottles]]. While not a great example scenario, this is to show something that can happen if you're not careful: Things working not as expected, as DirectorOptions have been set in ways that conflict, causing unexpected behaviors.


Information about some of the Director Options found in the [http://forums.steampowered.com/forums/showthread.php?t=1238461 Steam Forums].
When you see odd behavior like this, think about what other variables and objects might be interfering with your plans. Going back to the earlier example, the cause of this could be other scripts using a<code>DirectorOptions</code>table, so if you remember, you could try a<code>MutationOptions</code>table and see if it works. But if it doesn't, its okay, because if you inspect the keys documentation below, you'll find out the key<code>cm_CommonLimit</code>also exists, and could solve your other problems. Viewing the list of usable<code>DirectorOptions</code>keys can be very vital when debugging issues like these, sometimes you find something that just does what exactly you want.


<u>'''Don't forget to use the proper assignment operator!'''</u><br>
With a new DirectorOptions table, you should use the<code><-</code>operator. <code><-</code> is required over using the<code>local</code>tag and the<code>=</code> operator, as variables created with<code><-</code>become globals, allowing the C++ side of the game to use DirectorOptions.


:<strong style="color:#FF0000;">[[File:Warning.png|link=|alt=]] Warning:</strong> The Fields interact a lot
{{note|The default values are for reference of the values set elsewhere in-game (if it has one), and do NOT mean that the DirectorOption key is set by default. Blank values for a key also imply something simply has no default value.}}
:For instance, SpecialRespawnInterval is "how long after a special of type X dies can we spawn another one." Setting this fairly high (the default) makes a lot of sense in a flow based movement. Whereas if you are building a mutation where you stay in a single place, or where you want a ton of boomers, keeping it set high means that whenever you kill a boomer there will be a long wait until the Director is allowed to spawn a new one. So you'd want to set this value very low if your mod wants to do that.
 
:This brings up the main point: often things don't work as expected, because the DirectorOptions have been set in ways that conflict, causing unexpected behaviors. You can set 3 variables to get what you want, but a 4th may default to something that thwarts you. So it is worth learning about all the options, because it is very easy to over-constrain the Director. When you see odd behavior, think about what other variables and settings might be interfering with your plans.
 
 
:<strong style="color:#FF0000;">[[File:Warning.png|link=|alt=]] Warning:</strong> NEVER use the '''=''' operator when trying to influence the director. Use <-. The difference is semantics. If you use =, it will throw an error if the table slot isn't defined (like if a previous script didn't define it). <-, on the other hand, will create the variable if it does not exist. Some of these samples are only portions of a full script, so make sure that the variables are created beforehand.
 
 
{{note|The default values are for reference of the values set elsewhere in-game, and do NOT mean that the DirectorOption is set by default.}}


=== General ===
=== General ===
Line 178: Line 195:
! Default value
! Default value
! Description
! Description
|-
|<code>AddToSpawnTimer</code>
|
|
|
|-
|<code>AllowCrescendoEvents</code>
| bool
|
|
|-
|<code>AllowWitchesInCheckpoints</code>
| bool
|
|
|-
|-
|<code>AlwaysAllowWanderers</code>  
|<code>AlwaysAllowWanderers</code>  
| bool  
|bool  
|  
|false
|
|
|-
|-
|<code>BuildUpMinInterval</code>  
|<code>BuildUpMinInterval</code>  
|
|int
|  
|15
|
|Minimum time in seconds the BUILD_UP stage lasts.
|-
|-
|<code>ClearedWandererRespawnChance</code>  
|<code>ClearedWandererRespawnChance</code>  
|int
|int
|  
|0; 3 in Scavenge
|Percent chance (0-100) that cleared nav areas will get re-populated with wanderers.
|Percent chance (0-100) that cleared nav areas will get re-populated with wanderers.
|-
|-
|<code>DisallowThreatType</code>  
|<code>DisallowThreatType</code>  
|int
|int
|  
|
|Disallows boss types from being spawned in ''threat'' areas in coop mode. Valid flags are: <code>ZOMBIE_WITCH, ZOMBIE_TANK</code>
|Disallows boss types from being spawned in ''threat'' areas in coop mode. Valid flags are:<code>ZOMBIE_WITCH, ZOMBIE_TANK</code>
|-
<!--
|<code>FallenSurvivorPotentialQuantity</code>
These are found in director_c4_storm.nut, but don't actually do anything with the fallen survivor we know now:
|int
 
|
FallenSurvivorPotentialQuantity
|How many fallen survivors can spawn in total.
FallenSurvivorSpawnChance
|-
-->
|<code>FallenSurvivorSpawnChance</code>
|float
|
|[0...1]
|-
|-
|<code>FarAcquireRange</code>  
|<code>FarAcquireRange</code>  
|int
|float
|2500
|2500.0
|The maximum range common infected can spot survivors.
|The maximum range common infected can spot survivors.
|-
|-
|<code>NearAcquireRange</code>  
|<code>NearAcquireRange</code>  
|int
|float
|200
|200.0
|The range where common infected can spot survivors in the least amount of time.
|The range where common infected can spot survivors in the least amount of time.
|-
|-
Line 239: Line 237:
|The time it takes for an infected to acquire the survivor after spotting them at maximum range.
|The time it takes for an infected to acquire the survivor after spotting them at maximum range.
|-
|-
|<code>NearAcquireRange</code>  
|<code>NearAcquireTime</code>  
|float
|float
|0.5
|0.5
Line 246: Line 244:
|<code>GasCansOnBacks</code>  
|<code>GasCansOnBacks</code>  
|bool
|bool
|  
|false
|Puts the Hard Rain diesel cans on the survivors backs.
|Puts the Hard Rain diesel cans on the survivors backs.
|-
|<code>GetSpecialSlotCountdownTime</code>
|float
|
|
|-
|-
|<code>IgnoreNavThreatAreas</code>  
|<code>IgnoreNavThreatAreas</code>  
|bool
|bool
|  
|false
|Likely prevents bosses from spawning along the nav. {{todo|confirm category/working}}
|Likely prevents bosses from spawning along the nav. {{confirm|In proper category, and still working? Used in dash}}
|-
|-
|<code>InfectedFlags</code>  
|<code>InfectedFlags</code>  
|int
|int
|  
|0
|Applies flags to newly spawned infected. Valid flags are: <code>INFECTED_FLAG_CANT_SEE_SURVIVORS, INFECTED_FLAG_CANT_HEAR_SURVIVORS, INFECTED_FLAG_CANT_FEEL_SURVIVORS</code>
|Applies flags to newly spawned infected. Valid flags are: <code>INFECTED_FLAG_CANT_SEE_SURVIVORS, INFECTED_FLAG_CANT_HEAR_SURVIVORS, INFECTED_FLAG_CANT_FEEL_SURVIVORS</code>
|-
|-
|<code>IntensityRelaxAllowWanderersThreshold</code>  
|<code>IntensityRelaxAllowWanderersThreshold</code>  
|float
|float
|  
|0.8 in Expert; 0.5 in Advanced; 0.3 in other difficulties
|
|If the maximum intensity of the survivors is below this threshold, wandering commons can spawn.
|-
|-
|<code>IntensityRelaxThreshold</code>  
|<code>IntensityRelaxThreshold</code>  
|float
|float
|  
|0.9
|All survivors must be below this intensity before a Peak is allowed to switch to Relax (in addition to the normal peak timer)
|All survivors must be below this intensity before a Peak is allowed to switch to Relax (in addition to the normal peak timer)
|-
|-
|<code>JournalString</code>  
|<code>JournalString</code>  
|string
|string
|
|<nowiki>-none-</nowiki>
|{{todo|Used in holdout, seems to build some kind of table.}}
|{{todo|Used in holdout, seems to build some kind of table. Is this for the Director Journal related I/O inputs?}}
|-
|-
|<code>LockTempo</code>  
|<code>LockTempo</code>  
|bool
|bool
|false
|false, true in finales
|The horde spawning pacing consists of: BUILD_UP -> spawn horde -> SUSTAIN_PEAK -> RELAX -> BUILD_UP again. Setting  LockTempo = true removes the "SUSTAIN_PEAK -> RELAX -> BUILD_UP" bit making your hordes spawn constantly without a delay.
|Locks the Director tempo in the BUILD_UP phase. {{note|The phases cycle consists of: <nowiki>BUILD_UP -> SUSTAIN_PEAK -> PEAK_FADE -> RELAX -> BUILD_UP</nowiki> again. Hordes only spawn in the BUILD_UP tempo.}}
|-
|-
|<code>MobRechargeRate</code>  
|<code>MobRechargeRate</code>  
|int
|float
|
|0.0025
|Guessing it's the speed at which a mob regenerates (i.e. next mob).
|How fast a mob's CI spawn in-between each other.
|-
|-
|<code>MobSpawnMaxTime</code>  
|<code>MobSpawnMaxTime</code>  
|int
|float
|180-240
|180.0-240.0
|Maximum time in seconds between mob spawns. Default value depends on difficulty.
|Maximum time in seconds between mob spawns. Default value depends on difficulty.
|-
|-
|<code>MobSpawnMinTime</code>  
|<code>MobSpawnMinTime</code>  
|int
|float
|90-120
|90.0-120.0
|Minimum time in seconds between mob spawns. Default value depends on difficulty.
|Minimum time in seconds between mob spawns. Default value depends on difficulty.
|-
|-
|<code>MusicDynamicMobScanStopSize</code>  
|<code>MusicDynamicMobScanStopSize</code>  
|int
|int
|
|3
|When fewer than this many of a mob are in play, the mob music stops.
|When fewer than this many of a mob are in play, the mob music stops.
|-
|-
Line 306: Line 309:
|<code>MusicDynamicMobStopSize</code>  
|<code>MusicDynamicMobStopSize</code>  
|int
|int
|
|8
|When a mob gets to this size we think about stopping the mob music.
|When a mob gets to this size, the Director thinks about stopping the mob music.
|-
|-
|<code>NumReservedWanderers</code>  
|<code>NumReservedWanderers</code>  
|int
|int
|
|0
|The number of wandering infected that cannot be despawned for mobs.
|The number of wandering infected that cannot be despawned for mobs.
|-
|-
|<code>NoMobSpawns</code>  
|<code>PanicForever</code>  
|bool
|bool
|false
|false
|Prevents new mobs from spawning. Does not reset the timer, and already pending infected still spawn.
|-
|<code>PanicForever</code>
|int
|
|This seems to only work in gauntlets.
|This seems to only work in gauntlets.
|-
|-
|<code>PausePanicWhenRelaxing</code>  
|<code>PausePanicWhenRelaxing</code>  
|bool
|bool
|
|false
|{{todo|confirm category/working}}
|{{confirm|In proper category, and still working? Used in dash}}
|-
|-
|<code>PreferredMobDirection</code>  
|<code>PreferredMobDirection</code>  
|int
|int
|
|<nowiki>-1</nowiki>
|Valid flags are: <code>SPAWN_ABOVE_SURVIVORS, SPAWN_ANYWHERE, SPAWN_BEHIND_SURVIVORS, SPAWN_FAR_AWAY_FROM_SURVIVORS, SPAWN_IN_FRONT_OF_SURVIVORS, SPAWN_LARGE_VOLUME, SPAWN_NEAR_IT_VICTIM, SPAWN_NO_PREFERENCE</code>  
|Valid flags are: <code>SPAWN_ABOVE_SURVIVORS, SPAWN_ANYWHERE, SPAWN_BEHIND_SURVIVORS, SPAWN_FAR_AWAY_FROM_SURVIVORS, SPAWN_IN_FRONT_OF_SURVIVORS, SPAWN_LARGE_VOLUME, SPAWN_NEAR_IT_VICTIM, SPAWN_NO_PREFERENCE</code>  
{{note|<code>SPAWN_NEAR_IT_VICTIM</code> does not exist before a finale and will cause an error, so I'm assuming the director picks someone as IT when the finale starts. <code>SPAWN_LARGE_VOLUME</code> is what makes you be a mile away on DC finale.}}
{{note|<code>SPAWN_NEAR_IT_VICTIM</code> does not exist before a finale and will cause an error, so I'm assuming the director picks someone as IT when the finale starts.{{confirm}}}}
{{note|The flag names are case sensitive. Not using all caps will result in errors.}}
{{note|<code>SPAWN_LARGE_VOLUME</code>is what makes infected be a considerable distance away, like on Dead Center finale.
<br>{{todo|Explain more, and do it on a new page for<code>PreferredMobDirection</code>}} }}
|-
|-
|<code>PreferredMobPosition</code>  
|<code>PreferredMobPosition</code>  
|[[List_of_L4D2_Script_Functions#Vector|Vector]]
|[[Left 4 Dead 2/Scripting/Script Functions#Vector|Vector]]
|
|Vector(0, 0, 0)
|{{todo|confirm category/working; used in dash}}
|{{confirm|In proper category}}
|-
|-
|<code>PreferredMobPositionRange</code>  
|<code>PreferredMobPositionRange</code>  
|int
|float
|
|1000.0
|{{todo|confirm category/working; used in dash}}
|Only works if PreferredMobDirection is set to SPAWN_NEAR_POSITION.
{{confirm|In proper category}}
|-
|-
|<code>PreferredSpecialDirection</code>  
|<code>PreferredSpecialDirection</code>  
|int
|int
|
|<nowiki>-1</nowiki>
|{{note|The same values for <code>PreferredMobDirection</code> appear to work, BUT the following have also been seen, it is unknown if it's just redundancy.
|When set to <code>SPAWN_NO_PREFERENCE</code>, it behaves like this: If it's a smoker, it'll be <code>SPAWN_ABOVE_SURVIVORS</code>. If it's a charger, it'll be a 10% chance to be <code>SPAWN_BEHIND_SURVIVORS</code>, otherwise it's <code>SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS</code>. All other classes will be <code>SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS</code>. If any of these directions (including a manually specified one) fail to find a location, all retries will happen with <code>SPAWN_SPECIALS_ANYWHERE</code> as the direction.{{note|The same values for <code>PreferredMobDirection</code> appear to work, BUT the following have also been seen, it is unknown if it's just redundancy.
<code>SPAWN_SPECIALS_ANYWHERE, SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS</code>}}
<code>SPAWN_SPECIALS_ANYWHERE, SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS</code>}}
|-
|-
|<code>ProhibitBosses</code>  
|<code>ProhibitBosses</code>  
|bool
|bool
|
|false
|Prohibits tanks and witches from being spawned by the Director. Only functional in coop mode.
|Prohibits tanks and witches from being spawned by the Director in THREAT areas. Campaign modes only.
|-
|-
|<code>RelaxMaxFlowTravel</code>  
|<code>RelaxMaxFlowTravel</code>  
|float
|float
|
|3000
|How far the survivors can advance along the flow before transitioning from RELAX to BUILD_UP.
|How far the survivors can advance along the flow before transitioning from RELAX to BUILD_UP.
|-
|-
|<code>RelaxMaxInterval</code>  
|<code>RelaxMaxInterval</code>  
|float
|float
|
|45
|Maximum time to spend in the RELAX tempo.
|Maximum seconds to spend in the RELAX tempo.
|-
|-
|<code>RelaxMinInterval</code>  
|<code>RelaxMinInterval</code>  
|float
|float
|
|30
|Minimum time to spend in the RELAX tempo.
|Minimum seconds to spend in the RELAX tempo.
|-
|-
|<code>ShouldAllowMobsWithTank</code>  
|<code>ShouldAllowMobsWithTank</code>  
|bool
|bool
|
|false
|Whether to spawn mobs when a tank is in play. {{todo|confirm category/working; possibly finale specific}}
|Whether to allow spawning of infected mobs (except Boomer / Bile Bomb spawned mobs) when a tank is in play. Campaign modes only.
|-
|-
|<code>ShouldAllowSpecialsWithTank</code>  
|<code>ShouldAllowSpecialsWithTank</code>  
|bool
|bool
|
|false
|Whether to spawn Special Infected when a tank is in play. {{todo|confirm category/working; possibly finale specific}}
|Whether to allow spawning of Special Infected when a tank is in play. Campaign modes only.
{{warning|Causes the Director to spawn Special Infecteds by time, instead of tempo. }}
|-
|-
|<code>ShouldConstrainLargeVolumeSpawn</code>  
|<code>ShouldConstrainLargeVolumeSpawn</code>  
|bool
|bool
|
|true
|{{todo|confirm category/working}}
|If<code>SPAWN_LARGE_VOLUME</code>is used, it'll obey the restrictions imposed by the convars<code>z_large_volume_mob_too_far_xy</code>and<code>z_large_volume_mob_too_far_z</code>.<br>{{todo|Move to new page with images}}
|-
|-
|<code>ShouldIgnoreClearStateForSpawn</code>  
|<code>ShouldIgnoreClearStateForSpawn</code>  
|bool
|bool
|
|false
|{{todo|confirm category/working}}
|{{confirm|In proper category, and still working? Used in dash}}
|-
|-
|<code>SpawnBehindSurvivorsDistance</code>  
|<code>SpawnBehindSurvivorsDistance</code>  
|float
|  
|  
|
|Appears to require <code>PreferredSpecialfction = SPAWN_BEHIND_SURVIVORS</code>  
|Appears to require <code>PreferredSpecialDirection = SPAWN_BEHIND_SURVIVORS</code>  
|-
|-
|<code>SpecialInfectedAssault</code>  
|<code>SpecialInfectedAssault</code>  
|
|bool
|
|false
|{{todo|confirm category/working}}
|{{todo|confirm category/working}}
|-
|-
|<code>SpecialInitialSpawnDelayMax</code>  
|<code>SpecialInitialSpawnDelayMax</code>  
|float
|float
|
|60.0
|
|Specials cannot spawn for this many time maximum after the survivors exited the saferoom. Campaign modes only.
|-
|-
|<code>SpecialInitialSpawnDelayMin</code>  
|<code>SpecialInitialSpawnDelayMin</code>  
|float
|float
|
|30.0
|
|Specials cannot spawn for this many time minimum after the survivors exited the saferoom. Campaign modes only.
|-
|-
|<code>SpecialRespawnInterval</code>  
|<code>SpecialRespawnInterval</code>  
|float
|float
|
|45 in Campaign, 10 in Campaign finales, 20 in Versus
|Time in seconds before a Special Infected slot can respawn an infected.
|Time in seconds before a Special Infected slot can respawn an infected.
|-
|-
|<code>SurvivorMaxIncapacitatedCount</code>  
|<code>SurvivorMaxIncapacitatedCount</code>  
|int
|int
|
|2
|Maximum amount of survivor incapacitating before dying.
|Maximum amount of survivor incapacitating before dying.
|-
|-
|<code>SustainPeakMaxTime</code>  
|<code>SustainPeakMaxTime</code>  
|float
|float
|
|5
|in minutes
|in minutes{{confirm}}
|-
|-
|<code>SustainPeakMinTime</code>  
|<code>SustainPeakMinTime</code>  
|float
|float
|
|3
|in minutes
|in minutes{{confirm}}
|-
|-
|<code>TankHitDamageModifierCoop</code>  
|<code>TankHitDamageModifierCoop</code>  
|float
|float
|1.0
|1.0
|(mutation1.nut Last Man on Earth) {{todo|confirm category}}
|Damage dealt by Tanks is multiplied by this number in non PvP modes.
|-
|-
|<code>TankRunSpawnDelay</code>  
|<code>TankRunSpawnDelay</code>  
|float
|float
|15
|15
|in seconds (mutation19.nut Taaannnkk!) {{todo|confirm category}}
|in seconds (mutation19.nut Taaannnkk!) {{confirm|In proper category, and still working? Used in dash}}
|-
|<code>TempHealthDecayRate</code>
|float
|0.27
|0.27 is the <code>pain_pills_decay_rate</code> default, higher values equals quicker decay.
|-
|-
|<code>WanderingZombieDensityModifier</code>  
|<code>WanderingZombieDensityModifier</code>  
|float
|float
|1.0
|0.027 for versus, 0.03 otherwise
|Multiplier for the amount of wandering infected.
|Multiplier for the amount of wandering infected.
|-
|<code>WaterSlowsMovement</code>
|bool
|true
|Whether to apply slowdown to survivors in water. {{note|The campaign "The Sacrifice" manually places {{ent|trigger_playermovement}} in some of its maps's water.
|-
|-
|<code>ZombieDiscardRange</code>  
|<code>ZombieDiscardRange</code>  
|int
|int
|
|2500
|{{todo|possibly range for despawning wanderers}}
|Any CI beyond this point will be deleted, while any AI-controlled SI will suicide.
|-
|-
|<code>ZombieDontClear</code>  
|<code>ZombieDontClear</code>  
|
|bool
|
|false
|
|Do not mark nav areas as cleared.
|-
|-
|<code>ZombieSpawnInFog</code>  
|<code>ZombieSpawnInFog</code>  
Line 468: Line 471:
|<code>ZombieSpawnRange</code>  
|<code>ZombieSpawnRange</code>  
|float
|float
|
|1500.0
|Maximum distance from the survivors that the infected can spawn.
|Maximum distance from the survivors that the infected can spawn.
|-
|-
|<code>ZombieTankHealth</code>  
|<code>ZombieTankHealth</code>  
|int
|float
|
|4000.0
|Sets the amount of health a tank spawns with.
|Sets the amount of health a tank spawns with. The health is later affected by hidden health modifiers:<br>{{ExpandBox|
* Easy? - x0.75
* Advanced?, Expert? - x2
* Versus modes? - x1.5
}}
|}
|}


==== Spawning limits ====
==== Spawning limits ====
{{warning|Only the limits for bosses affect [[info_zombie_spawn|spawners]].}}


{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
Line 488: Line 496:
| int
| int
|  
|  
|Number of commons that spawn when a bile bomb is thrown. Appears to only work in finale. Found in Dead Center and The Sacrifice finales.
|Number of commons spawned in a mob when a bile bomb is thrown or a survivor is hit by vomit. Also controls the common limit if a survivor is currently vomited on. Only works if either scripted mode is enabled or the finale is active. Found in the Dead Center and The Passing finales.
{{note|The common limit is not changed if the finale is a gauntlet finale.}}
|-
|-
|<code>BoomerLimit</code>  
|<code>BoomerLimit</code>  
Line 507: Line 516:
|<code>DominatorLimit</code>  
|<code>DominatorLimit</code>  
|int
|int
|  
|2
|Maximum number of Hunters, Smokers, Jockeys and Chargers allowed to be in play simultaneously. {{todo|confirm category/working}}
|Maximum number of dominator SI types (Hunter, Smoker, Jockey or Charger) that can freely fill up their caps. The extra SI type (3rd by default) will be capped at 1 regardless of its individual limit or<code>cm_BaseSpecialLimit</code>. Therefore, if<code>cm_BaseSpecialLimit = 2</code>,<code>MaxSpecials = 8</code>and<code>DominatorLimit</code>is unset, the maximum amount of dominators will be 2+2+1+0. The remaining 3 slots could only be filled with Boomers and Spitters. Its maximum effective value is 4 since there are only 4 dominator types. To block all dominators, set it to -1.
|-
|-
|<code>HunterLimit</code>  
|<code>HunterLimit</code>  
Line 527: Line 536:
|<code>MegaMobSize</code>  
|<code>MegaMobSize</code>  
|int
|int
|
|50
|The amount of total infected spawned during a panic event.
|The amount of total infected spawned during a panic event.
|-
|-
|<code>MobMaxPending</code>  
|<code>MobMaxPending</code>  
|int
|int
|
|<nowiki>-1</nowiki>
|How many infected can be left pending to spawn when the mob size is larger than <code>CommonLimit</code>.
|How many infected can be left pending to spawn when the mob size is larger than <code>CommonLimit</code>.
|-
|-
Line 547: Line 556:
|<code>MobSpawnSize</code>  
|<code>MobSpawnSize</code>  
|int
|int
|
|<nowiki>-none-</nowiki>
|Static amount of infected in a mob. Likely overrides <code>MobMinSize</code> and <code>MobMinSize</code>.
|Static amount of infected in a mob. Overrides <code>MobMinSize</code> and <code>MobMaxSize</code>.
|-
|-
|<code>PreTankMobMax</code>  
|<code>PreTankMobMax</code>  
|int
|int
|
|50
|{{todo|confirm category/working; possibly gauntlet finale specific}}
|{{confirm|In proper category, and still working? Possibly Gauntlet finale specific?}}
|-
|-
|<code>SmokerLimit</code>  
|<code>SmokerLimit</code>  
|bool
|int
|1
|1
|Maximum number of Smokers allowed to be in play simultaneously.
|Maximum number of Smokers allowed to be in play simultaneously.
Line 567: Line 576:
|<code>TankLimit</code>  
|<code>TankLimit</code>  
|int
|int
|1
|<nowiki>-1</nowiki> <!-- z_spawn can spawn infinite Tanks by default, but can't if this is set -->
|Maximum number of Tanks allowed to be in play simultaneously.
|Maximum number of Tanks allowed to be in play simultaneously.
|-
|-
|<code>WitchLimit</code>  
|<code>WitchLimit</code>  
|int
|int
|1
|<nowiki>-1</nowiki>
|Maximum number of Witches allowed to be in play simultaneously.1
|Maximum number of Witches allowed to be in play simultaneously. Less than 0 means no maximum.
|}
|}


Line 580: Line 589:


'''See [[L4D2_EMS/Appendix:_Spawning_Infected]]'''
'''See [[L4D2_EMS/Appendix:_Spawning_Infected]]'''


{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
Line 587: Line 595:
! Default value
! Default value
! Description
! Description
|-
|<code>AddToSpawnTimer</code>
|float
|0.0
| {{Todo|needs more testing but it's related to adding time to special timers when stage changes}}
|-
|<code>AllowCrescendoEvents</code>
|bool
|true
|
|-
|-
|<code>PanicSpecialsOnly</code>  
|<code>PanicSpecialsOnly</code>  
|bool
|bool
|
|false
|The Panic should end when we finish with Specials, not wait for the MegaMob.
|The Panic should end when we finish with Specials, not wait for the MegaMob.
|-
|-
Line 605: Line 623:
|<code>ScriptedStageType</code>  
|<code>ScriptedStageType</code>  
|int
|int
|
|9
|The type of stage to run next. See [[L4D2_EMS/StageTypeAppendix]] for a description of stage types.
|The type of stage to run next. See [[L4D2_EMS/StageTypeAppendix]] for a description of stage types.
|-
|-
|<code>ScriptedStageValue</code>  
|<code>ScriptedStageValue</code>  
|int
|int
|
|1
|Dependant on the stage type.
|Dependant on the stage type.
|-
|-
|<code>SpawnDirectionCount</code>  
|<code>SpawnDirectionCount</code>  
|
|int
|
|0
|{{todo|confirm category/working}}
|{{todo|confirm category/working}}
|-
|-
|<code>SpawnDirectionMask</code>  
|<code>SpawnDirectionMask</code>  
|int
|int
|
|0
|A bitfield (using <code>SPAWNDIR_N, _NE, _E</code>, etc) of directors to spawn from _relative to_ a map entity named <code>Compass</code> in your map. Designed for Survival-like game modes. See [[L4D2_EMS/Appendix:_Spawning_Infected]].
|A bitfield (using <code>SPAWNDIR_N, _NE, _E</code>, etc) of directors to spawn from _relative to_ a map entity named <code>Compass</code> in your map. Designed for Survival-like game modes. See [[L4D2_EMS/Appendix:_Spawning_Infected]].
|-
|-
|<code>SpawnSetPosition</code>  
|<code>SpawnSetPosition</code>  
|[[List_of_L4D2_Script_Functions#Vector|Vector]]
|[[Left 4 Dead 2/Scripting/Script Functions#Vector|Vector]]
|
|
|The center point of the area infected can spawn in, when <code>SpawnSetRule</code> is set to <code>SPAWN_POSITIONAL</code>.
|The center point of the area infected can spawn in, when <code>SpawnSetRule</code> is set to <code>SPAWN_POSITIONAL</code>.
|-
|-
|<code>SpawnSetRadius</code>  
|<code>SpawnSetRadius</code>  
|int
|float
|
|1000.0
|How far from the center point infected can spawn, when <code>SpawnSetRule</code> is set to <code>SPAWN_POSITIONAL</code>.
|How far from the center point infected can spawn, when <code>SpawnSetRule</code> is set to <code>SPAWN_POSITIONAL</code>.
|-
|-
|<code>SpawnSetRule</code>  
|<code>SpawnSetRule</code>  
|int
|int
|
|0
|Overrides the mode of spawning used. Seems to be non-functional in finales. Valid flags are: <code>SPAWN_ANYWHERE, SPAWN_FINALE, SPAWN_BATTLEFIELD, SPAWN_SURVIVORS, SPAWN_POSITIONAL</code>
|Overrides the mode of spawning used. Seems to be non-functional in finales. Valid flags are: <code>SPAWN_ANYWHERE, SPAWN_FINALE, SPAWN_BATTLEFIELD, SPAWN_SURVIVORS, SPAWN_POSITIONAL</code>
|-
|-
|<code>TotalBoomers</code>  
|<code>TotalBoomers</code>  
|int
|int
|
|0
|Number of Boomers allowed in a wave.
|Number of Boomers allowed in a wave.
|-
|-
|<code>TotalChargers</code>  
|<code>TotalChargers</code>  
|int
|int
|
|0
|Number of Chargers allowed in a wave.
|Number of Chargers allowed in a wave.
|-
|-
|<code>TotalHunters</code>  
|<code>TotalHunters</code>  
|int
|int
|
|0
|Number of Hunters allowed in a wave.
|Number of Hunters allowed in a wave.
|-
|-
|<code>TotalJockeys</code>  
|<code>TotalJockeys</code>  
|int
|int
|
|0
|Number of Jockeys allowed in a wave.
|Number of Jockeys allowed in a wave.
|-
|-
|<code>TotalSmokers</code>  
|<code>TotalSmokers</code>  
|int
|int
|
|0
|Number of Smokers allowed in a wave.
|Number of Smokers allowed in a wave.
|-
|-
|<code>TotalSpecials</code>  
|<code>TotalSpecials</code>  
|int
|int
|
|0
|Total number of Special Infected allowed in a wave.
|Total number of Special Infected allowed in a wave.
|-
|-
Line 673: Line 691:
|Number of Spitters allowed in a wave.
|Number of Spitters allowed in a wave.
|}
|}
*'''function <code>void g_ModeScript::GetNextStage()</code> '''
: Called by the director when it wants a new stage. It can be forced with <code>Director.ForceNextStage()</code>


=== Finale Specific/Related ===
=== Finale Specific/Related ===
A normal finale consists of X number of stages. Some variables in DirectorOptions can only be used during finales. Multiple staged events can be defined in the same script, with the Options starting with <code>A_, B_, C_ etc.</code>
A normal finale consists of X number of stages. Some variables in DirectorOptions can only be used during finales. Multiple custom finales can be defined in the same script, with the Options starting with <code>A_, B_, C_, D_, E_</code>. Which finale is used will be chosen randomly.


{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
Line 686: Line 701:
! Description
! Description
|-
|-
|<code>''A''_CustomFinale_StageCount</code>  
|<code>''[A-E]''_CustomFinale_StageCount</code>  
|int
|int
|
|<nowiki>-none-</nowiki>
|Number of stages. Needs to be set for Versus scoring to function properly.
|Number of stages. Needs to be set for Versus scoring to function properly.
|-
|-
|<code>''A''_CustomFinale''X''</code>  
|<code>''[A-E]''_CustomFinale''X''</code>  
|int
|int
|
|<nowiki>-none-</nowiki>
|Stage type (enumerated PANIC, SCRIPTED (AKA ONSLAUGHT), DELAY, TANK), where X is the stage number. Also used in scripted panic events.
|Stage type (enumerated PANIC, SCRIPTED (AKA ONSLAUGHT), DELAY, TANK), where X is the corresponding stage number. Usable in scripted panic events.
|-
|-
|<code>''A''_CustomFinaleValue''X''</code>  
|<code>''[A-E]''_CustomFinaleValue''X''</code>  
|*
|any
|
|<nowiki>-none-</nowiki>
|Value depends on the stage type above. Also used in scripted panic events. Please see the example above.
|Value depends on the stage type above. Usable in scripted panic events.
|-
|-
|<code>''A''_CustomFinaleMusic''X''</code>  
|<code>''[A-E]''_CustomFinaleMusic''X''</code>  
|string
|string
|
|<nowiki>-none-</nowiki>
|[[Soundscript]] entry to play. For instance, <code>A_CustomFinaleMusic1 = "C2M5.BadManTank2"</code>. Note that c2m5_concert_finale.nut does not use this method and instead opted to use entities within the map instead. In the c2m5 script <code>A_CustomFinaleMusic4 = ""</code>, suggesting that no song is actually played automatically via script.
|[[Soundscript]] entry to play. For instance, <code>A_CustomFinaleMusic1 = "C2M5.BadManTank2"</code> will play a Dark Carnival - Concert finale song. Does not work in Scripted Panic Events.
{{note|Dark Carnival - Concert finale does not use this method! It instead uses map logic and [[ambient_music]]. However its finale script has<code>A_CustomFinaleMusic4<nowiki>= ""</nowiki></code>, suggesting that it may be disabling the default Tank music.}}
|-
|-
|<code>EnforceFinaleNavSpawnRules</code>  
|<code>EnforceFinaleNavSpawnRules</code>  
|bool
|bool
|
|true
|Possibly used to enforce the finale spawning behavior without running a finale. {{todo|confirm category/working}}
|Possibly used to enforce the finale spawning behavior without running a finale. {{todo|confirm category/working}}
|-
|-
|<code>HordeEscapeCommonLimit</code>  
|<code>HordeEscapeCommonLimit</code>  
|
|int
|
|<nowiki>-1</nowiki>
|Number of commons allowed in the escape stage.
|Number of commons allowed in the escape stage.
|-
|-
|<code>EscapeSpawnTanks</code>  
|<code>EscapeSpawnTanks</code>  
|bool
|bool
|
|true
|Whether to spawn tanks in the escape sequence. {{todo|possibly EMS stage related}}
|Whether to spawn tanks in the escape sequence. {{todo|possibly EMS stage related}}
|-
|-
|<code>MinimumStageTime</code>  
|<code>MinimumStageTime</code>  
|int
|float
|
|1.0
|The minimum amount of time a SCRIPTED stage is allowed to run before ending.
|The minimum amount of time a SCRIPTED stage is allowed to run before ending. Unavailable for Scripted Panic Events.
|}
|}


=== Gauntlet Specific/Related ===
=== Gauntlet Specific/Related ===
Line 738: Line 753:
|-
|-
|<code>CustomTankKiteDistance</code>  
|<code>CustomTankKiteDistance</code>  
|int
|float
|3000
|3000.0
|{{todo|confirm category/working}}
|Controls when the Gauntlet's Tank wave should start if a survivor advanced this far, in flow distance.
|}
|}


;'''Movement Bonus related options'''
:Movement Bonus are an unique RELAX pacing method present only in Gauntlet finales. Everytime the Movement Timer finishes its timing, Movement Bonus is incremented by its set value. However if a new mob spawns, the Director initiates an extra variable afterwards: Current Bonus. Current Bonus is a timer that lasts as long as the current Movement Bonus, which when still ticking down, disallows the Director from spawning any new infecteds (except Tanks).


;'''Movement Bonus related options'''
To familiarize with Movement Bonus better, use<code>director_debug 1</code>in-game to see the values.
:The Movement Bonus successively increases the delay between hordes when the survivors are not making progress toward the Gauntlet goal. The Current Bonus value ticks down every second, allows a horde to spawn when it reaches 0. When a horde spawns the Current Bonus is reset to the Movement Bonus value. The Movement Bonus increases at set intervals, and is reset when the survivors cross the Movement Threshold, which is then incremented. Use <code>director_debug 1</code> to see the values.


{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
Line 755: Line 771:
|<code>GauntletMovementThreshold</code>  
|<code>GauntletMovementThreshold</code>  
|float
|float
|
|500.0
|The amount of flow units the survivors can advance before the Movement Bonus is reset.
|When survivors advance this many amount of flow distance, from the last reset point or the start point, Movement Bonus, Movement Timer and Current Bonus is reset to defaults.
|-
|-
|<code>GauntletMovementTimerLength</code>  
|<code>GauntletMovementTimerLength</code>  
|float
|float
|
|5.0
|The interval between each Movement Bonus increase, in seconds.
|The interval between each Movement Bonus increase, in seconds.
|-
|-
|<code>GauntletMovementBonus</code>  
|<code>GauntletMovementBonus</code>  
|float
|float
|
|2.0
|The initial value, and the amount the movement Bonus increases each interval, in seconds.
|The initial value, and the amount the movement Bonus increases everytime the timer stops, in seconds.
|-
|-
|<code>GauntletMovementBonusMax</code>  
|<code>GauntletMovementBonusMax</code>  
|float
|float
|
|30.0
|The maximum value that the Movement Bonus can reach.
|The maximum value that the Movement Bonus can store.
|}
|}


=== Versus Specific ===
=== Versus Specific ===
Line 786: Line 801:
|float
|float
|1.0
|1.0
|
|Damage dealt by Tanks is multiplied by this number in PvP modes.
|-
|-
|<code>ZombieGhostDelayMax</code>  
|<code>ZombieGhostDelayMax</code>  
|int
|float
|30
|30.0
|Maximum time in seconds until allowing player infected to respawn.
|Maximum time in seconds until allowing player infected to respawn.
|-
|-
|<code>ZombieGhostDelayMin</code>  
|<code>ZombieGhostDelayMin</code>  
|int
|float
|20
|20.0
|Minimum time in seconds until allowing player infected to respawn.
|Minimum time in seconds until allowing player infected to respawn.
|}
|}


=== Scavenge Specific/Related ===
=== Scavenge Specific/Related ===
Line 810: Line 824:
|<code>ScavengeClusterBonusTime</code>  
|<code>ScavengeClusterBonusTime</code>  
|float
|float
|
|15.0
|{{todo|confirm category/working}}
|{{todo|confirm category/working}}
|-
|-
|<code>ScavengeRoundInitialTime</code>  
|<code>ScavengeRoundInitialTime</code>  
|float
|float
|
|90.0
|{{todo|confirm category/working}}
|The timer's initial length when the round starts.
|-
|-
|<code>ScavengeScoreBonusTime</code>  
|<code>ScavengeScoreBonusTime</code>  
|float
|float
|
|15.0
|(used in mutation13.nut Follow the Liter)
|Amount of time added to the timer when a gascan is successfully poured.
|}
|}


=== Survival Specific/Related ===
=== Survival Specific/Related ===
Line 838: Line 851:
|(Used in mutation15.nut for Survival Versus with setup time of 90 seconds)
|(Used in mutation15.nut for Survival Versus with setup time of 90 seconds)
|}
|}


=== Mutation Specific/Related ===
=== Mutation Specific/Related ===
Some of these values are mutation specific values of the global ones (cm_CommonLimit,cm_MaxSpecials, etc.), so use them if you are making a mutation, in case any map scripts are changing the global values.
Some of these values are mutation specific values of the global ones (cm_CommonLimit,cm_MaxSpecials, etc.), so use them if you are making a mutation, in case any map scripts are changing the global values.
{{note|These options need scripted mode to be active (e.g. running a mutation)}}


{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
Line 848: Line 861:
! Default value
! Default value
! Description
! Description
|-
|<code>ActiveChallenge</code>
|bool
|false
|Activates mutation mode. {{note|Seems to be obsolete with the EMS update.}}
|-
|<code>AllowWitchesInCheckpoints</code>
|bool
|false
|Whether Witches are allowed to access nav areas marked with CHECKPOINT.
|-
|-
|<code>cm_AggressiveSpecials</code>  
|<code>cm_AggressiveSpecials</code>  
|bool
|bool
|true
|false
|
|If enabled, Special Infected will always go straight after the Survivors instead of possibly waiting around.
|-
|-
|<code>cm_AllowPillConversion</code>  
|<code>cm_AllowPillConversion</code>  
|bool
|bool
|true
|true
|Allows pills to be converted to health kits.
|Allows pills to be converted to health kits or defibrillators in non-Expert difficulties.
|-
|-
|<code>cm_AllowSurvivorRescue</code>  
|<code>cm_AllowSurvivorRescue</code>  
|bool
|bool
|
|true if base mode is <code>coop</code>, false otherwise
|
|Controls whether survivors can be respawned in rescue closets.
|-
|-
|<code>cm_AutoReviveFromSpecialIncap</code>  
|<code>cm_AutoReviveFromSpecialIncap</code>  
|bool
|bool
|false
|false
|Instantly revives a survivor when incapacitated by a Special Infected.
|Instantly revives a survivor when incapacitated by a Special Infected. {{Note|Doesn't work if a player isn't incapacitated by being dominated.|only=l4d2}}
|-
|-
|<code>cm_AutoSpawnInfectedGhosts</code>  
|<code>cm_AutoSpawnInfectedGhosts</code>  
|bool
|bool
|
|false
|
|
|-
|-
|<code>cm_BaseCommonAttackDamage</code>  
|<code>cm_BaseCommonAttackDamage</code>  
|
|float
|
|1.0
|
|
|-
|-
Line 882: Line 905:
|int
|int
|
|
|
|Controls the default max limits of all the Special Infected. {{note|Overridden by individual special limits. See https://github.com/Tsuey/L4D2-Community-Update/issues/317.}}
|-
|-
|<code>cm_CommonLimit</code>  
|<code>cm_CommonLimit</code>  
|int
|int
|
|
|
|Identical to the<code>CommonLimit</code> key, except this key will be prioritized over any<code>CommonLimit</code>keys.
|-
|<code>cm_DominatorLimit</code>  
|int
|
|
|-
|-
|<code>cm_FirstManOut</code>  
|<code>cm_FirstManOut</code>  
|int
|bool
|false
|false
|Ends the escape when the first survivor reaches the escape vehicle.
|Ends the escape when the first survivor reaches the escape vehicle.
|-
|<code>cm_frustrationTimer</code>
|
|
|
|-
|-
|<code>cm_HeadshotOnly</code>  
|<code>cm_HeadshotOnly</code>  
|
|bool
|
|false
|
|Every infected only takes damage when shot to the head, else they will only stumble. Tanks are excepted from this. Used in the mutation "Headshot!"
|-
|-
|<code>cm_HealingGnome</code>  
|<code>cm_HealingGnome</code>  
|
|bool
|
|false
|
|All survivors start with only temporary health, with a gnome to be picked up near of them; The gnome will slowly regenerate the health of anyone who holds it. Used in the mutation "Healing Gnome."
|-
|-
|<code>cm_InfiniteFuel</code>  
|<code>cm_InfiniteFuel</code>  
|
|bool
|
|false
|(mutation7.nut Chainsaw Massacre)
|(mutation7.nut Chainsaw Massacre)
|-
|-
|<code>cm_MaxSpecials</code>  
|<code>cm_MaxSpecials</code>  
|
|int
|
|<nowiki>-none-</nowiki>
|
|Identical to the<code>MaxSpecials</code> key, except this key will be priortized over any<code>MaxSpecials</code>keys.
|-
|<code>cm_NoRescueClosets</code>  
|
|
|
|-
|-
|<code>cm_NoSurvivorBots</code>  
|<code>cm_NoSurvivorBots</code>  
|
|bool
|
|false
|
|Should survivor bots be kicked on round start? {{todo|Improve description, add side effects}}
|-
|-
|<code>cm_ProhibitBosses</code>  
|<code>cm_ProhibitBosses</code>  
|
|bool
|
|<nowiki>-none-</nowiki>
|
|Identical to the<code>ProhibitBosses</code> key, except this key will be priortized over any<code>ProhibitBosses</code>keys.
|-
|-
|<code>cm_ShouldEscortHumanPlayers</code>  
|<code>cm_ShouldEscortHumanPlayers</code>  
|
|bool
|
|
|
|
|-
|-
|<code>cm_ShouldHurry</code>  
|<code>cm_ShouldHurry</code>  
|
|bool
|
|false
|
|Prompt survivor bots to rush as they would in Versus.
|-
|-
|<code>cm_SingleScavengeCluster</code>  
|<code>cm_SingleScavengeCluster</code>  
|
|bool
|
|false
|Used for scavenge cans to spawn one-by-one.
|Only a group of scavenge cans together will be active at once. Used in the mutation "Follow the Liter."
|-
|-
|<code>cm_SpecialRespawnInterval</code>  
|<code>cm_SpecialRespawnInterval</code>  
|
|int
|
|<nowiki>-none-</nowiki>
|
|Identical to the<code>SpecialRespawnInterval</code> key, except this key will be priortized over any<code>SpecialRespawnInterval</code>keys.
|-
|-
|<code>cm_SpecialSlotCountdownTime</code>  
|<code>cm_SpecialSlotCountdownTime</code>  
|int
|
|
|
|Used in Hunting Party (mutation16.nut). {{todo|Is this the same as<code>cm_SpecialRespawnInterval</code>?}}
|
|-
|-
|<code>cm_SpecialsRetreatToCover</code>  
|<code>cm_SpecialsRetreatToCover</code>  
|
|bool
|
|false
|
|
|-
|-
|<code>cm_TankLimit</code>  
|<code>cm_TankLimit</code>  
|
|int
|
|<nowiki>-none-</nowiki>
|
|Identical to the<code>TankLimit</code> key, except this key will be priortized over any<code>TankLimit</code>keys.
|-
|-
|<code>cm_TankRun</code>  
|<code>cm_TankRun</code>  
|
|bool
|
|false
|Used in Taaank! mutation (mutation19.nut).
|Allows bypassing c7m1's second train door. Used in Taaannnkk! (mutation19.nut) and Tank Run mutations.  
|-
|-
|<code>cm_TempHealthOnly</code>  
|<code>cm_TempHealthOnly</code>  
|
|bool
|
|false
|
|
|-
|-
|<code>cm_VIPTarget</code>  
|<code>cm_VIPTarget</code>  
|
|bool
|
|false
|
|Spawns a gnome in the safe area of each map that must be carried to the end of the map. Used in the mutation "Last Gnome on Earth"
|-
|-
|<code>cm_WanderingZombieDensityModifier</code>  
|<code>cm_WanderingZombieDensityModifier</code>  
|
|float
|
|0.027 for versus, 0.03 otherwise
|
|Identical to the<code>WanderingZombieDensityModifier</code> key, except this key will be priortized over any<code>WanderingZombieDensityModifier</code>keys.
|-
|-
|<code>cm_WitchLimit</code>  
|<code>cm_WitchLimit</code>  
|
|int
|
|<nowiki>-none-</nowiki>
|
|Identical to the<code>WitchLimit</code> key, except this key will be priortized over any<code>WitchLimit</code>keys.
|}
 
 
=== Defunct options ===
These don't seem to be read by the director.
 
{| class="standard-table" style="width: 100%;"
! Name
! Type
! Default value
! Description
|-
|-
|<code>ActiveChallenge</code>  
|<code>NoMobSpawns</code>  
|bool
|bool
|false
|false
|Activates mutation mode. Seems to be obsolete with the EMS update.
|Prevents new mobs from attempting to spawn. Does not reset the timer, and already pending infected still spawn.
|-
|-
|<code>MegaMobMaxSize</code>  
|<code>TempHealthDecayRate</code>  
|int
|float
|
|0.27
|Maximum amount of total infected spawned during a panic event. Doesn't work 2014.04.29
|0.27 is the <code>pain_pills_decay_rate</code> default, higher values equals quicker decay. {{important|If you add this to your MutationOptions don't delete it later in an attempt to get back to defaults. This option directly changes <code>pain_pills_decay_rate</code> cvar and is the only proper way to change that cvar dynamically.}}
|-
|<code>MegaMobMinSize</code>  
|int
|
|Minimum amount of total infected spawned during a panic event. Doesn't work 2014.04.29
|}
|}


 
=== Callback Functions ===
=== Hook Functions ===  
When functions with these specific names are placed in the DirectorOptions table, they get called by C++ with specific arguments used.
These functions are placed in the DirectorOptions table, and get called at map load.
==== Scripted mode callbacks ====
 
{| class="standard-table" style="width: 100%;"
{| class="standard-table" style="width: 100%;"
! Function
! Function
Line 1,035: Line 1,026:
! Description
! Description
|-
|-
| <code>AllowWeaponSpawn</code>
| <code>[[L4D2_Director_Scripts/AllowFallenSurvivorItem|AllowFallenSurvivorItem]]</code>
| <code>bool AllowFallenSurvivorItem(string ''classname'')</code>
| For the given weapon classnames, return true to allow Fallen Survivors to carry the item, false / none is otherwise.
|-
| <code>[[L4D2_Director_Scripts/AllowWeaponSpawn|AllowWeaponSpawn]]</code>
| <code>bool AllowWeaponSpawn(string ''classname'')</code>
| <code>bool AllowWeaponSpawn(string ''classname'')</code>
| Returns true or false if the given classname is allowed to spawn, used by several mutations.
| Return false to the given string to disallow the respective weapon from spawning, used by several mutations.
|-
|-
| <code>ConvertWeaponSpawn</code>
| <code>ConvertWeaponSpawn</code>
| <code>string ConvertWeaponSpawn(string ''classname'')</code>
| <code>string ConvertWeaponSpawn(string ''classname'')</code>
| Converts a weapon spawn of given classname to another, used by several mutations.
| For the given weapon classname, return another classname to convert the weapon to another, used by several mutations.
|-
|-
| <code>ConvertZombieClass</code>
| <code>ConvertZombieClass</code>
| <code>int ConvertZombieClass(''infectedClass'')</code>
| <code>int ConvertZombieClass(int ''infectedClass'')</code>
| Converts one spawn into another, used by the Taaannnk!! mutation (mutation19.nut).
| Converts player-controlled Special Unfecteds into another. Used by the Taaannnk!! (<code style="color:#E5E5E5;">mutation19.nut</code>) and Riding My Survivor (<code style="color:#E5E5E5;">community3.nut</code>) mutations.
|-
| <code>EndScriptedMode</code>
| <code>int EndScriptedMode()</code>
| Called when the game attempts to end a round to allow changing the mission lost scenario or even preventing it. Used by the Dash mutation.
|-
|-
| <code>GetDefaultItem</code>
| <code>GetDefaultItem</code>
| <code>string GetDefaultItem(index)</code>
| <code>string GetDefaultItem(int ''index'')</code>
| Repeatedly called with incrementing indices. Return a string of a weapon name to make it a default item for survivors, or 0 to end the iteration.
| Repeatedly called with incrementing indices. Return a string of a weapon name to make it a default item for survivors, or 0 to end the iteration.
|-
|-
| <code>ShouldAvoidItem</code>
| <code>ShouldAvoidItem</code>
| <code>bool ShouldAvoidItem(string ''classname'')</code>
| <code>bool ShouldAvoidItem(string ''classname'')</code>
| {{todo|Probably a bot related function or spawn related}}
| Return true or false to the given weapon classname to either make bots dislike or prefer a weapon. Used in mutations such as Four Swordsmen (<code style="color:#E5E5E5;">mutation5.nut</code>) or Chainsaw Massacre (<code style="color:#E5E5E5;">mutation7.nut</code>).
|-
| <code>ShouldPlayBossMusic</code>
| <code>bool ShouldPlayBossMusic(int ''index'')</code>
| Whether the standard Tank music (<code>Event.Tank</code>) should be force played in a Tank fight. Normally, the standard Tank music is only played before finales and the finale variants (<code>Event.TankMidpoint</code> and <code>Event.TankBrothers</code>) only played during Tank stages (specifically <code>FINALE_FINAL_BOSS</code> for the second variant). Returning <code>true</code> will override the finale Tank music variant in Tank stages and also allow the standard Tank music in other stages. Returning <code>false</code> will silence the music even outside finales.
{{todo|What is the <code>index</code>?}}
|}
 
==== Internal callbacks ====
{{warning|The following are internal/technical callbacks that should not be used directly by users.}}
{| class="standard-table" style="width: 100%;"
! Function
! Signature
! Description
|-
| <code>OnChangeFinaleStage</code>
| <code>void OnChangeFinaleStage(int ''finaletype'', int ''stagetype'')</code>
| Called right before <code>[[#Callbacks|OnBeginCustomFinaleStage]]</code>. <code>finaletype</code> refers to the {{ent|trigger_finale}}'s '''Finale Type''' keyvalue. <code>stagetype</code> follows the special, <code>FINALE_</code> prefixed, enumeration. It is used by [[director_base.nut]] to set the default music for finale stages by modifying the variable <code>OnChangeFinaleMusic</code>. As such, it's only called for stages without a ''_CustomFinaleMusic'' and is unsuitable for general use.
|}
 
=== Data mining ===
The following are data mined Director options that may have never been functional in-game.
{| class="standard-table" style="width: 100%;"
! Name
! Type
! Default value
! Description
|-
|<code>cm_AllowTeamSwap</code>
|bool
|true
|
|}
|}


== Enumerations ==
== Enumerations ==
List of enumerations from {{code|DirectorScript}} table. If you have a script that intends to access these but won't be ran with the [[info_director]]'s inputs, access them in this manner to avoid errors: {{code|DirectorScript.ALLOW_BASH_ALL}}.
Some enumerations here are bitmasked, so they can be combined with other ones. Any hook / callback functions are stylized in ''italics''.
{{Note|These aren't actual [http://squirrel-lang.org/doc/squirrel3.html#d0e1892 Squirrel enumerations], but rather table slots ''dressed up'' like constants.}}


*Director Enumerations {{note|These are (or some are) '''script specific''', hence the duplicate values.}}
;[[Left 4 Dead 2/Scripting/Script Functions#AllowBash|''AllowBash'']]
**ALLOW_BASH_ALL = 0
*ALLOW_BASH_ALL = 0
**ALLOW_BASH_NONE = 2
*ALLOW_BASH_PUSHONLY = 1
**ALLOW_BASH_PUSHONLY = 1
*ALLOW_BASH_NONE = 2
**BOT_CANT_FEEL = 4
 
**BOT_CANT_HEAR = 2
;[[Left 4 Dead 2/Scripting/Script Functions#CTerrorPlayer|CTerrorPlayer::GetSenseFlags or CTerrorPlayer::SetSenseFlags]] (Bitmasks)
**BOT_CANT_SEE = 1
*BOT_CANT_SEE = 1
**BOT_CMD_ATTACK = 0
*BOT_CANT_HEAR = 2
**BOT_CMD_MOVE = 1
*BOT_CANT_FEEL = 4
**BOT_CMD_RESET = 3
 
**BOT_CMD_RETREAT = 2
;[[Left 4 Dead 2/Scripting/Script Functions/CommandABot|CommandABot]]
**BOT_QUERY_NOTARGET = 1
*BOT_CMD_ATTACK = 0
**DMG_BLAST = 64
*BOT_CMD_MOVE = 1
**DMG_BLAST_SURFACE = 134217728
*BOT_CMD_RETREAT = 2
**DMG_BUCKSHOT = 536870912
*BOT_CMD_RESET = 3
**DMG_BULLET = 2
 
**DMG_BURN = 8
;[[Left 4 Dead 2/Scripting/Script Functions#BotQuery|''BotQuery'']]
**DMG_HEADSHOT = 1073741824
*BOT_QUERY_NOTARGET = 1
**DMG_MELEE = 2097152
 
**DMG_STUMBLE = 33554432
;[[Left 4 Dead 2/Scripting/Script Functions#CBaseEntity|CBaseEntity::TakeDamage]] or [[Left 4 Dead 2/Scripting/Script Functions#AllowTakeDamage|''AllowTakeDamage'']] (Bitmasks)
**FINALE_CUSTOM_CLEAROUT = 11
*DMG_BULLET = 2
**FINALE_CUSTOM_DELAY = 10
*DMG_BURN = 8
**FINALE_CUSTOM_PANIC = 7
*DMG_BLAST = 64 (0x40)
**FINALE_CUSTOM_SCRIPTED = 9
*DMG_MELEE = 2097152 (0x200000) (also known as {{code|DMG_SLOWBURN}} in other Source games)
**FINALE_CUSTOM_TANK = 8
*DMG_STUMBLE = 33554432 (0x2000000)
**FINALE_FINAL_BOSS = 5
*DMG_BLAST_SURFACE = 134217728 (0x8000000)
**FINALE_GAUNTLET_1 = 0
*DMG_BUCKSHOT = 536870912 (0x20000000)
**FINALE_GAUNTLET_2 = 3
*DMG_HEADSHOT = 1073741824 (0x40000000)
**FINALE_GAUNTLET_BOSS = 16
 
**FINALE_GAUNTLET_BOSS_INCOMING = 15
;[[#Internal callbacks|''DirectorOptions.OnChangeFinaleStage'']]
**FINALE_GAUNTLET_ESCAPE = 17
*FINALE_GAUNTLET_1 = 0
**FINALE_GAUNTLET_HORDE = 13
*FINALE_HORDE_ATTACK_1 = 1
**FINALE_GAUNTLET_HORDE_BONUSTIME = 14
*FINALE_HALFTIME_BOSS = 2
**FINALE_GAUNTLET_START = 12
*FINALE_GAUNTLET_2 = 3
**FINALE_HALFTIME_BOSS = 2
*FINALE_HORDE_ATTACK_2 = 4
**FINALE_HORDE_ATTACK_1 = 1
*FINALE_FINAL_BOSS = 5
**FINALE_HORDE_ATTACK_2 = 4
*FINALE_HORDE_ESCAPE = 6
**FINALE_HORDE_ESCAPE = 6
*FINALE_CUSTOM_PANIC = 7
**HUD_FAR_LEFT = 7
*FINALE_CUSTOM_TANK = 8
**HUD_FAR_RIGHT = 8
*FINALE_CUSTOM_SCRIPTED = 9
**HUD_FLAG_ALIGN_CENTER = 512
*FINALE_CUSTOM_DELAY = 10
**HUD_FLAG_ALIGN_LEFT = 256
*FINALE_CUSTOM_CLEAROUT = 11
**HUD_FLAG_ALIGN_RIGHT = 768
*FINALE_GAUNTLET_START = 12
**HUD_FLAG_ALLOWNEGTIMER = 128
*FINALE_GAUNTLET_HORDE = 13
**HUD_FLAG_AS_TIME = 16
*FINALE_GAUNTLET_HORDE_BONUSTIME = 14
**HUD_FLAG_BEEP = 4
*FINALE_GAUNTLET_BOSS_INCOMING = 15
**HUD_FLAG_BLINK = 8
*FINALE_GAUNTLET_BOSS = 16
**HUD_FLAG_COUNTDOWN_WARN = 32
*FINALE_GAUNTLET_ESCAPE = 17
**HUD_FLAG_NOBG = 64
 
**HUD_FLAG_NOTVISIBLE = 16384
;[[L4D2 EMS/Appendix: HUD|Ticker_AddToHud]]
**HUD_FLAG_POSTSTR = 2
:<u>FLAGS</u>
**HUD_FLAG_PRESTR = 1
:*HUD_FLAG_PRESTR = 1
**HUD_FLAG_TEAM_INFECTED = 2048
:*HUD_FLAG_POSTSTR = 2
**HUD_FLAG_TEAM_MASK = 3072
:*HUD_FLAG_BEEP = 4
**HUD_FLAG_TEAM_SURVIVORS = 1024
:*HUD_FLAG_BLINK = 8
**HUD_LEFT_BOT = 1
:*HUD_FLAG_AS_TIME = 16
**HUD_LEFT_TOP = 0
:*HUD_FLAG_COUNTDOWN_WARN = 32
**HUD_MID_BOT = 3
:*HUD_FLAG_NOBG = 64
**HUD_MID_BOX = 9
:*HUD_FLAG_ALLOWNEGTIMER = 128
**HUD_MID_TOP = 2
:*HUD_FLAG_ALIGN_LEFT = 256
**HUD_RIGHT_BOT = 5
:*HUD_FLAG_ALIGN_CENTER = 512
**HUD_RIGHT_TOP = 4
:*HUD_FLAG_ALIGN_RIGHT = 768
**HUD_SCORE_1 = 11
:*HUD_FLAG_TEAM_SURVIVORS = 1024
**HUD_SCORE_2 = 12
:*HUD_FLAG_TEAM_INFECTED = 2048
**HUD_SCORE_3 = 13
:*HUD_FLAG_TEAM_MASK = 3072
**HUD_SCORE_4 = 14
:*HUD_FLAG_NOTVISIBLE = 16384
**HUD_SCORE_TITLE = 10
:<u>SLOTS</u>
**HUD_SPECIAL_COOLDOWN = 4
:*HUD_LEFT_TOP = 0
**HUD_SPECIAL_MAPNAME = 6
:*HUD_LEFT_BOT = 1
**HUD_SPECIAL_MODENAME = 7
:*HUD_MID_TOP = 2
**HUD_SPECIAL_ROUNDTIME = 5
:*HUD_MID_BOT = 3
**HUD_SPECIAL_TIMER0 = 0
:*HUD_RIGHT_TOP = 4
**HUD_SPECIAL_TIMER1 = 1
:*HUD_RIGHT_BOT = 5
**HUD_SPECIAL_TIMER2 = 2
:*HUD_TICKER = 6
**HUD_SPECIAL_TIMER3 = 3
:*HUD_FAR_LEFT = 7
**HUD_TICKER = 6
:*HUD_FAR_RIGHT = 8
**INFECTED_FLAG_CANT_FEEL_SURVIVORS = 32768
:*HUD_MID_BOX = 9
**INFECTED_FLAG_CANT_HEAR_SURVIVORS = 16384
:*HUD_SCORE_TITLE = 10
**INFECTED_FLAG_CANT_SEE_SURVIVORS = 8192
:*HUD_SCORE_1 = 11
**IN_ATTACK = 1
:*HUD_SCORE_2 = 12
**IN_ATTACK2 = 2048
:*HUD_SCORE_3 = 13
**IN_BACK = 16
:*HUD_SCORE_4 = 14
**IN_CANCEL = 64
:<u>SPECIAL</u>
**IN_DUCK = 4
:*HUD_SPECIAL_TIMER0 = 0
**IN_FORWARD = 8
:*HUD_SPECIAL_TIMER1 = 1
**IN_JUMP = 2
:*HUD_SPECIAL_TIMER2 = 2
**IN_LEFT = 512
:*HUD_SPECIAL_TIMER3 = 3
**IN_RELOAD = 8192
:*HUD_SPECIAL_COOLDOWN = 4
**IN_RIGHT = 1024
:*HUD_SPECIAL_ROUNDTIME = 5
**IN_USE = 32
:*HUD_SPECIAL_MAPNAME = 6
**SCRIPTED_SPAWN_BATTLEFIELD = 2
:*HUD_SPECIAL_MODENAME = 7
**SCRIPTED_SPAWN_FINALE = 0
 
**SCRIPTED_SPAWN_POSITIONAL = 3
;[[Left 4 Dead 2/Scripting/Script Functions/ClientPrint|ClientPrint]]
**SCRIPTED_SPAWN_SURVIVORS = 1
*HUD_PRINTNOTIFY = 1
**SCRIPT_SHUTDOWN_EXIT_GAME = 4
*HUD_PRINTCONSOLE = 2
**SCRIPT_SHUTDOWN_LEVEL_TRANSITION = 3
*HUD_PRINTTALK = 3
**SCRIPT_SHUTDOWN_MANUAL = 0
*HUD_PRINTCENTER = 4
**SCRIPT_SHUTDOWN_ROUND_RESTART = 1
 
**SCRIPT_SHUTDOWN_TEAM_SWAP = 2
;[[#General|DirectorOptions.InfectedFlags]] or [[Left 4 Dead 2/Scripting/Script Functions#Other|ReapplyInfectedFlags]] (Bitmasks)
**SPAWNDIR_E = 4
*INFECTED_FLAG_CANT_SEE_SURVIVORS = 8192 (0x2000)
**SPAWNDIR_N = 1
*INFECTED_FLAG_CANT_HEAR_SURVIVORS = 16384 (0x4000)
**SPAWNDIR_NE = 2
*INFECTED_FLAG_CANT_FEEL_SURVIVORS = 32768 (0x8000)
**SPAWNDIR_NW = 128
 
**SPAWNDIR_S = 16
;[[Left 4 Dead 2/Scripting/Script Functions#CTerrorPlayer|CTerrorPlayer::GetButtonMask]] (Bitmasks)
**SPAWNDIR_SE = 8
*IN_ATTACK = 1
**SPAWNDIR_SW = 32
*IN_JUMP = 2
**SPAWNDIR_W = 64
*IN_DUCK = 4
**SPAWN_ABOVE_SURVIVORS = 6
*IN_FORWARD = 8
**SPAWN_ANYWHERE = 0
*IN_BACK = 16 (0x10)
**SPAWN_BATTLEFIELD = 2
*IN_USE = 32 (0x20)
**SPAWN_BEHIND_SURVIVORS = 1
*IN_CANCEL = 64 (0x40)
**SPAWN_FAR_AWAY_FROM_SURVIVORS = 5
*IN_LEFT = 512 (0x200)
**SPAWN_FINALE = 0
*IN_RIGHT = 1024 (0x400)
**SPAWN_IN_FRONT_OF_SURVIVORS = 7
*IN_ATTACK2 = 2048 (0x800)
**SPAWN_LARGE_VOLUME = 9
*IN_RELOAD = 8192 (0x2000)
**SPAWN_NEAR_IT_VICTIM = 2
 
**SPAWN_NEAR_POSITION = 10
;[[Left 4 Dead 2/Scripting/Script Functions#TerrorNavArea|TerrorNavArea]] or [[Left 4 Dead 2/Scripting/Script Functions#CNavLadder|CNavLadder]]
**SPAWN_NO_PREFERENCE = -1
*LADDER_UP = 0
**SPAWN_POSITIONAL = 3
*LADDER_DOWN = 1
**SPAWN_SPECIALS_ANYWHERE = 4
 
**SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS = 3
;[[Left 4 Dead 2/Scripting/Script Functions#TerrorNavArea|TerrorNavArea]] or [[Left 4 Dead 2/Scripting/Script Functions#CNavLadder|CNavLadder]]
**SPAWN_SURVIVORS = 1
*NAV_NORTH = 0
**SPAWN_VERSUS_FINALE_DISTANCE = 8
*NAV_EAST = 1
**STAGE_CLEAROUT = 4
*NAV_SOUTH = 2
**STAGE_DELAY = 2
*NAV_WEST = 3
**STAGE_ESCAPE = 7
 
**STAGE_NONE = 9
;[[#EMS Stage Specific|DirectorOptions.SpawnSetRule]]
**STAGE_PANIC = 0
*SCRIPTED_SPAWN_FINALE = 0
**STAGE_RESULTS = 8
*SCRIPTED_SPAWN_SURVIVORS = 1
**STAGE_SETUP = 5
*SCRIPTED_SPAWN_BATTLEFIELD = 2
**STAGE_TANK = 1
*SCRIPTED_SPAWN_POSITIONAL = 3
**TIMER_COUNTDOWN = 2
 
**TIMER_COUNTUP = 1
;[[#EMS Stage Specific|DirectorOptions.SpawnSetRule]]
**TIMER_DISABLE = 0
*SPAWN_FINALE = 0
**TIMER_SET = 4
*SPAWN_SURVIVORS = 1
**TIMER_STOP = 3
*SPAWN_BATTLEFIELD = 2
**TRACE_MASK_ALL = -1
*SPAWN_POSITIONAL = 3
**TRACE_MASK_NPC_SOLID = 33701899
 
**TRACE_MASK_PLAYER_SOLID = 33636363
;SCRIPT_SHUTDOWN {{todo|Are these for the VS 2010 debugger?}}
**TRACE_MASK_SHOT = 1174421507
*SCRIPT_SHUTDOWN_MANUAL = 0
**TRACE_MASK_VISIBLE_AND_NPCS = 33579137
*SCRIPT_SHUTDOWN_ROUND_RESTART = 1
**TRACE_MASK_VISION = 33579073
*SCRIPT_SHUTDOWN_TEAM_SWAP = 2
**UPGRADE_EXPLOSIVE_AMMO = 1
*SCRIPT_SHUTDOWN_LEVEL_TRANSITION = 3
**UPGRADE_INCENDIARY_AMMO = 0
*SCRIPT_SHUTDOWN_EXIT_GAME = 4
**UPGRADE_LASER_SIGHT = 2
 
**ZOMBIE_BOOMER = 2
;[[#EMS Stage Specific|DirectorScript.SpawnDirectionMask]] (Bitmasks)
**ZOMBIE_CHARGER = 6
*SPAWNDIR_N = 1
**ZOMBIE_HUNTER = 3
*SPAWNDIR_NE = 2
**ZOMBIE_JOCKEY = 5
*SPAWNDIR_E = 4
**ZOMBIE_NORMAL = 0
*SPAWNDIR_SE = 8
**ZOMBIE_SMOKER = 1
*SPAWNDIR_S = 16 (0x10)
**ZOMBIE_SPITTER = 4
*SPAWNDIR_SW = 32 (0x20)
**ZOMBIE_TANK = 8
*SPAWNDIR_W = 64 (0x40)
**ZOMBIE_WITCH = 7
*SPAWNDIR_NW = 128 (0x80)
**ZSPAWN_MOB = 10
 
**ZSPAWN_MUDMEN = 12
;[[#General|DirectorOptions.PreferredMobDirection or DirectorOptions.PreferredSpecialDirection]]
**ZSPAWN_WITCHBRIDE = 11
*SPAWN_NO_PREFERENCE = -1
*SPAWN_ANYWHERE = 0
*SPAWN_BEHIND_SURVIVORS = 1
*SPAWN_NEAR_IT_VICTIM = 2
*SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS = 3
*SPAWN_SPECIALS_ANYWHERE = 4
*SPAWN_FAR_AWAY_FROM_SURVIVORS = 5
*SPAWN_ABOVE_SURVIVORS = 6
*SPAWN_IN_FRONT_OF_SURVIVORS = 7
*SPAWN_VERSUS_FINALE_DISTANCE = 8
*SPAWN_LARGE_VOLUME = 9
*SPAWN_NEAR_POSITION = 10
 
;[[L4D2 EMS/StageTypeAppendix|DirectorOptions.ScriptedStageType]]
*STAGE_PANIC = 0
*STAGE_TANK = 1
*STAGE_DELAY = 2
*STAGE_CLEAROUT = 4
*STAGE_SETUP = 5
*STAGE_ESCAPE = 7
*STAGE_RESULTS = 8
*STAGE_NONE = 9
 
;[[Left 4 Dead 2/Scripting/Script Functions/TraceLine|TraceLine]] (Bitmasks){{todo|Is this a bitmask or what? If yes, then the term's definition in the second paragraph should be revised as these can't be independently combined.}}
*TRACE_MASK_ALL = -1
*TRACE_MASK_VISION = 33579073
*TRACE_MASK_VISIBLE_AND_NPCS = 33579137
*TRACE_MASK_PLAYER_SOLID = 33636363
*TRACE_MASK_NPC_SOLID = 33701899
*TRACE_MASK_SHOT = 1174421507
 
;[[Left 4 Dead 2/Scripting/Script Functions#Printing and Drawing|HUDManageTimers]]
*TIMER_DISABLE = 0
*TIMER_COUNTUP = 1
*TIMER_COUNTDOWN = 2
*TIMER_STOP = 3
*TIMER_SET = 4
 
;[[Left 4 Dead 2/Scripting/Script Functions#CTerrorPlayer|CTerrorPlayer::GiveUpgrade]]
*UPGRADE_INCENDIARY_AMMO = 0
*UPGRADE_EXPLOSIVE_AMMO = 1
*UPGRADE_LASER_SIGHT = 2
 
;[[Left 4 Dead 2/Scripting/Script Functions/ZSpawn|ZSpawn]]
*ZOMBIE_NORMAL = 0
*ZOMBIE_SMOKER = 1
*ZOMBIE_BOOMER = 2
*ZOMBIE_HUNTER = 3
*ZOMBIE_SPITTER = 4
*ZOMBIE_JOCKEY = 5
*ZOMBIE_CHARGER = 6
*ZOMBIE_WITCH = 7
*ZOMBIE_TANK = 8
*ZSPAWN_MOB = 10
*ZSPAWN_MUDMEN = 12
*ZSPAWN_WITCHBRIDE = 11


== See also ==
== See also ==
*[[List of L4D2 Script Functions]]
=== Intros ===
*[[VScript]]
*[[L4D2 Vscripts|L4D2 VScripts]]
*[[Mutation Gametype (L4D2)]]
=== Documentations ===
*[[Left 4 Dead 2/Scripting/Script Functions]]
*[[L4D2_Decrypted_mutations|Decrypted Mutation Vscripts]]
*[[L4D2_Level_Design/Boss_Prohibition|L4D2 Level Design/Boss Prohibition]]
*[[L4D2 Vscript Examples]]
*[[L4D2 Vscript Examples]]
*[[L4D2 EMS|Extended Mutation System]]
*[[L4D2 EMS|Extended Mutation System]]
*[[L4D2_Level_Design/Custom_Finale|Custom Finales]] ''Contains all original finale scripts as reference.''
=== Miscelleanous ===
*[[Logic_script|logic_script]]
*[[L4D2_Level_Design/Boss_Prohibition|L4D2 Level Design/Boss Prohibition]]
*[[L4D2_Level_Design/Boss_Prohibition|L4D2 Level Design/Boss Prohibition]]
*[[Trigger_finale|trigger_finale]]
*[[Trigger_finale|trigger_finale]]
*[[Info_director|info_director]]
*[[Info_director|info_director]]
*[[VScript|vscripts]]


[[Category:Left_4_Dead_2]]
[[Category:Left_4_Dead_2]]
[[Category:Scripting]]
[[Category:Scripting]]

Latest revision as of 10:28, 4 October 2025

English (en)中文 (zh)Translate (Translate)

SquirrelLeft 4 Dead 2 Left 4 Dead 2 Director scripts are vscripts that are primarily used to influence the behavior of the AI Director. They are extensively used for custom finales and gauntlet events.

Usage

Director scripts typically contain a table named DirectorOptions, which contains variables that change up the decision making of the Director. They can be ran / stopped with the following inputs to the info_director entity:

BeginScript <scriptlistRedirectInput/string>
Run Director scripts, and parse their DirectorOptions table once. If a Director script is already running and this input is called, the previous Director script automatically stops running.
EndScript
Ends the running script and resets the Director options to either the map's DirectorOptions values, or the default settings.
ScriptedPanicEvent <scriptlistRedirectInput/string>
With the script names given they'll be ran as a scripted panic event, which is like a mini finale, so a script should be structured as a finale script.
Note.pngNote:Scripts used with these inputs will not work if they are in a subdirectory under thevscriptsfolder, even though you can use subdirectories in other script contexts. Events will play out only the 1 second DELAY "stage 0" if they violate this.

There is also a CDirector object for VScripts, and its extra functions can be paired for customizing your Director scripts.

General scripts and Onslaughts

Scripts launched with the BeginScript Director input run until a different script is launched, or the script is manually ended with the EndScript input. Unless new Director Options are set, the gameplay continues on as normally.

Onslaught events are created by manipulating the pacing and spawn limits of mobs and special infected.

c2m4_barns_onslaught.nut (with annotations):

Msg("Initiating Onslaught\n");

DirectorOptions <-
{
	// This turns off tanks and witches (when true).
	ProhibitBosses = false
	
	//LockTempo = true

	// Sets the time between mob spawns. Mobs can only spawn when the pacing is in the BUILD_UP state.
	MobSpawnMinTime = 1
	MobSpawnMaxTime = 1

	// How many zombies are in each mob.
	MobMinSize = 30
	MobMaxSize = 30
	MobMaxPending = 30

	// Modifies the length of the SUSTAIN_PEAK and RELAX states to shorten the time between mob spawns.
	SustainPeakMinTime = 5
	SustainPeakMaxTime = 10
	IntensityRelaxThreshold = 0.99
	RelaxMinInterval = 1
	RelaxMaxInterval = 5
	RelaxMaxFlowTravel = 50

	//Special infected options
	SpecialRespawnInterval = 1.0
        SmokerLimit = 2
        JockeyLimit = 0
        BoomerLimit = 0
        HunterLimit = 2
        ChargerLimit = 1

	// Valid spawn locations
	PreferredMobDirection = SPAWN_NO_PREFERENCE
	ZombieSpawnRange = 2000
}

Director.ResetMobTimer()		// Sets the mob spawn timer to 0.
Director.PlayMegaMobWarningSounds()	// Plays the incoming mob sound effect.

Finales and Scripted Panic Events

The structure of custom finales and scripted panic events (or mini-finales) setup their structure with a script. In the script, its DirectorOptions table defines:


  • Total wave count
  • Type of each wave, and a value
  • Optional alternative waves

To load a custom finale script, nothing extra needs to be done other than naming the script as [current map]_finale.nut. The script will be automatically loaded when the custom finale starts.

However, scripted panic events are different; they are always manual, and initiated by inputting ScriptedPanicEvent [scriptfilename] to info_director without file extensions nor parent folders.

Icon-Bug.pngBug:In Scripted Panic Events:
  • Sending an EndCustomScriptedStage input or running Director.ForceNextStage() during a SCRIPTED stage ends the whole event.
  • When the last stage ends, its repeated once more but with the default values. Effects are as follows:

  • PANIC and TANK stages will repeat with only 1x Wave / Tank.
  • DELAY and SCRIPTED stages repeat, but are then skipped immediately.
Note.pngNote:The repeating bug can be circumvented by using the ONSLAUGHT/SCRIPTED stage to call another director script which ends the event via an EndCustomScriptedStage input to the info_director entity.


Setting up Stages

There are 4 main types of stages (visit StageTypeAppendix for others):

Name Value Description
PANIC 0 A panic event; The value is the number of infected waves.
TANK 1 Spawn tank(s), with the value as the number of tanks to spawn.
DELAY 2 A delay, its value is the number of seconds to wait before it goes to the next stage.
SCRIPTED 3 Sometimes with the ONSLAUGHTname; sets up a stage using the loaded script's contents. The value is the name of the relevant VScript (with no file extension).

In SCRIPTED, the script is fully responsible for dictating when it'll end! To end the stage, send the EndCustomScriptedStage input to a info_director entity. Moreover on finales, these two can be used instead:


Code Sample

An example custom finale script, that also makes use of various finale settings documented at later parts of this page:

const ERROR = -1
const PANIC = 0
const TANK = 1
const DELAY = 2
const SCRIPTED = 3 

DirectorOptions <-
{
	//-----------------------------------------------------
	A_CustomFinale_StageCount = 3 // Number of stages. Used for calculating the Versus score.
	B_CustomFinale_StageCount = 3 // Number of stages for the alternate B finale type
	
	A_CustomFinale1 = PANIC
	A_CustomFinaleValue1 = 2	// Two panic waves.
	
	A_CustomFinale2 = DELAY
	A_CustomFinaleValue2 = 5 	// Delay for five seconds in addition to stage delay.
	
	A_CustomFinale3 = TANK
	A_CustomFinaleValue3 = 3 	// 3 tanks! Start rescue for Finale Type A after this wave ends too.
	
	B_CustomFinale1 = SCRIPTED
	B_CustomFinaleValue1 = "my_scripted_stage"	// Start of with running a custom scripted stage using a separate script.
	
	B_CustomFinale2 = TANK
	B_CustomFinaleValue2 = 1 	// Follow up with a single tank.

	B_CustomFinale3 = DELAY
	B_CustomFinaleValue3 = 5	// Wait five more seconds ... rescue for Finale Type B!

	//-----------------------------------------------------

	CommonLimit = 10
	SpecialRespawnInterval = 25
}

function OnBeginCustomFinaleStage( num, type ) // This function is run at the beginning of every stage.
{
	printl( "Beginning custom finale stage #" + num + " of type: " + type )
	if( DirectorOptions.CommonLimit < 30 )
		DirectorOptions.CommonLimit = num * 5 // Increase commons by 5 linearly with stages.
}

See a list of all official finale scripts here.

Adaptive Dramatic Pacing

Todo: Add info from [1]

Callbacks

When functions with these specific names are placed in a Director script scope table (see delegation rules), they get called by C++ with specific arguments used.

LocalScript based callbacks

  • float GetCustomScriptedStageProgress(float defvalue)
Will be called during FINALE_CUSTOM_SCRIPTED stages. The function should return a value from 0-1 to indicate the completion percentage of the stage. The default time-based completion percentage is passed in as a parameter.
  • void OnBeginCustomFinaleStage(int num, int type)
Will be called on every scripted panic event or finale stage change. This is how you would change director options between stages (spawn directions, etc). num refers to the finale stage number passed by the director and type is the stage type (PANIC, TANK, etc.) following the standard, STAGE_ prefixed, enumeration.
Icon-Bug.pngBug:The CEntities object will not work properly in this callback, always returning the default value null every tick until Squirrel terminates the script.

ChallengeScript based callbacks

  • void GetNextStage()
Called by the director when it wants a new stage. It can be forced with Director.ForceNextStage(). Used by Dash, Holdout and Tank Run.

DirectorOptions

TheDirectorOptionstable is used for overriding various Director variables that govern among other things: infected spawning rough distance, finale stages, and others.

In mode and map scripts, use SessionOptions and MutationOptions/MapOptions! SessionOptions for influencing the director, while the MutationOptions/MapOptions tables for setting default values. This is because BaseScriptedDOTable has priority and overrides some initial parameters in the DirectorOptions table of the mode script scope (see MergeSessionOptionTables in scriptedmode.nut).

Note.pngNote:'Mode scripts' term refer to scripts ran when a specific gamemode is active, like shootzones.nut. 'Map scripts' on the other hand, could run anytime during a map, dependent of map logic. Examples for this include: c3m1_plankcountry_holdout.nut,c9m1_minifinale.nut and c11m4_reserved_wanderers.nut.

Though, while customizing the Director's behaviour, you might come across these issues:

The Fields interact a lot!
Say you have a custom mutation mod, and you use aDirectorOptionstable to influence the Director. It reducesCommonLimit for lesser Commons, but also reduces bothMobSpawnTimeMinandMobSpawnTimeMax to make them respawn faster. However, when playtesting your mod on Dead Center, everything seems to revert to default after you complete the Gauntlet fetch quest, featuring weapon_cola_bottles. While not a great example scenario, this is to show something that can happen if you're not careful: Things working not as expected, as DirectorOptions have been set in ways that conflict, causing unexpected behaviors.

When you see odd behavior like this, think about what other variables and objects might be interfering with your plans. Going back to the earlier example, the cause of this could be other scripts using aDirectorOptionstable, so if you remember, you could try aMutationOptionstable and see if it works. But if it doesn't, its okay, because if you inspect the keys documentation below, you'll find out the keycm_CommonLimitalso exists, and could solve your other problems. Viewing the list of usableDirectorOptionskeys can be very vital when debugging issues like these, sometimes you find something that just does what exactly you want.

Don't forget to use the proper assignment operator!
With a new DirectorOptions table, you should use the<-operator. <- is required over using thelocaltag and the= operator, as variables created with<-become globals, allowing the C++ side of the game to use DirectorOptions.

Note.pngNote:The default values are for reference of the values set elsewhere in-game (if it has one), and do NOT mean that the DirectorOption key is set by default. Blank values for a key also imply something simply has no default value.

General

Name Type Default value Description
AlwaysAllowWanderers bool false
BuildUpMinInterval int 15 Minimum time in seconds the BUILD_UP stage lasts.
ClearedWandererRespawnChance int 0; 3 in Scavenge Percent chance (0-100) that cleared nav areas will get re-populated with wanderers.
DisallowThreatType int Disallows boss types from being spawned in threat areas in coop mode. Valid flags are:ZOMBIE_WITCH, ZOMBIE_TANK
FarAcquireRange float 2500.0 The maximum range common infected can spot survivors.
NearAcquireRange float 200.0 The range where common infected can spot survivors in the least amount of time.
FarAcquireTime float 5.0 The time it takes for an infected to acquire the survivor after spotting them at maximum range.
NearAcquireTime float 0.5 The time it takes for an infected to acquire the survivor after spotting them at minimum range.
GasCansOnBacks bool false Puts the Hard Rain diesel cans on the survivors backs.
GetSpecialSlotCountdownTime float
IgnoreNavThreatAreas bool false Likely prevents bosses from spawning along the nav.
Confirm:In proper category, and still working? Used in dash
InfectedFlags int 0 Applies flags to newly spawned infected. Valid flags are: INFECTED_FLAG_CANT_SEE_SURVIVORS, INFECTED_FLAG_CANT_HEAR_SURVIVORS, INFECTED_FLAG_CANT_FEEL_SURVIVORS
IntensityRelaxAllowWanderersThreshold float 0.8 in Expert; 0.5 in Advanced; 0.3 in other difficulties If the maximum intensity of the survivors is below this threshold, wandering commons can spawn.
IntensityRelaxThreshold float 0.9 All survivors must be below this intensity before a Peak is allowed to switch to Relax (in addition to the normal peak timer)
JournalString string -none-
Todo: Used in holdout, seems to build some kind of table. Is this for the Director Journal related I/O inputs?
LockTempo bool false, true in finales Locks the Director tempo in the BUILD_UP phase.
Note.pngNote:The phases cycle consists of: BUILD_UP -> SUSTAIN_PEAK -> PEAK_FADE -> RELAX -> BUILD_UP again. Hordes only spawn in the BUILD_UP tempo.
MobRechargeRate float 0.0025 How fast a mob's CI spawn in-between each other.
MobSpawnMaxTime float 180.0-240.0 Maximum time in seconds between mob spawns. Default value depends on difficulty.
MobSpawnMinTime float 90.0-120.0 Minimum time in seconds between mob spawns. Default value depends on difficulty.
MusicDynamicMobScanStopSize int 3 When fewer than this many of a mob are in play, the mob music stops.
MusicDynamicMobSpawnSize int 25 Spawning a mob this large will play the mob music.
MusicDynamicMobStopSize int 8 When a mob gets to this size, the Director thinks about stopping the mob music.
NumReservedWanderers int 0 The number of wandering infected that cannot be despawned for mobs.
PanicForever bool false This seems to only work in gauntlets.
PausePanicWhenRelaxing bool false
Confirm:In proper category, and still working? Used in dash
PreferredMobDirection int -1 Valid flags are: SPAWN_ABOVE_SURVIVORS, SPAWN_ANYWHERE, SPAWN_BEHIND_SURVIVORS, SPAWN_FAR_AWAY_FROM_SURVIVORS, SPAWN_IN_FRONT_OF_SURVIVORS, SPAWN_LARGE_VOLUME, SPAWN_NEAR_IT_VICTIM, SPAWN_NO_PREFERENCE
Note.pngNote:SPAWN_NEAR_IT_VICTIM does not exist before a finale and will cause an error, so I'm assuming the director picks someone as IT when the finale starts.[confirm]
Note.pngNote:The flag names are case sensitive. Not using all caps will result in errors.
Note.pngNote:SPAWN_LARGE_VOLUMEis what makes infected be a considerable distance away, like on Dead Center finale.
Todo: Explain more, and do it on a new page forPreferredMobDirection
PreferredMobPosition Vector Vector(0, 0, 0)
Confirm:In proper category
PreferredMobPositionRange float 1000.0 Only works if PreferredMobDirection is set to SPAWN_NEAR_POSITION.
Confirm:In proper category
PreferredSpecialDirection int -1 When set to SPAWN_NO_PREFERENCE, it behaves like this: If it's a smoker, it'll be SPAWN_ABOVE_SURVIVORS. If it's a charger, it'll be a 10% chance to be SPAWN_BEHIND_SURVIVORS, otherwise it's SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS. All other classes will be SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS. If any of these directions (including a manually specified one) fail to find a location, all retries will happen with SPAWN_SPECIALS_ANYWHERE as the direction.
Note.pngNote:The same values for PreferredMobDirection appear to work, BUT the following have also been seen, it is unknown if it's just redundancy. SPAWN_SPECIALS_ANYWHERE, SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS
ProhibitBosses bool false Prohibits tanks and witches from being spawned by the Director in THREAT areas. Campaign modes only.
RelaxMaxFlowTravel float 3000 How far the survivors can advance along the flow before transitioning from RELAX to BUILD_UP.
RelaxMaxInterval float 45 Maximum seconds to spend in the RELAX tempo.
RelaxMinInterval float 30 Minimum seconds to spend in the RELAX tempo.
ShouldAllowMobsWithTank bool false Whether to allow spawning of infected mobs (except Boomer / Bile Bomb spawned mobs) when a tank is in play. Campaign modes only.
ShouldAllowSpecialsWithTank bool false Whether to allow spawning of Special Infected when a tank is in play. Campaign modes only.
Warning.pngWarning:Causes the Director to spawn Special Infecteds by time, instead of tempo.
ShouldConstrainLargeVolumeSpawn bool true IfSPAWN_LARGE_VOLUMEis used, it'll obey the restrictions imposed by the convarsz_large_volume_mob_too_far_xyandz_large_volume_mob_too_far_z.
Todo: Move to new page with images
ShouldIgnoreClearStateForSpawn bool false
Confirm:In proper category, and still working? Used in dash
SpawnBehindSurvivorsDistance float Appears to require PreferredSpecialfction = SPAWN_BEHIND_SURVIVORS
SpecialInfectedAssault bool false
Todo: confirm category/working
SpecialInitialSpawnDelayMax float 60.0 Specials cannot spawn for this many time maximum after the survivors exited the saferoom. Campaign modes only.
SpecialInitialSpawnDelayMin float 30.0 Specials cannot spawn for this many time minimum after the survivors exited the saferoom. Campaign modes only.
SpecialRespawnInterval float 45 in Campaign, 10 in Campaign finales, 20 in Versus Time in seconds before a Special Infected slot can respawn an infected.
SurvivorMaxIncapacitatedCount int 2 Maximum amount of survivor incapacitating before dying.
SustainPeakMaxTime float 5 in minutes[confirm]
SustainPeakMinTime float 3 in minutes[confirm]
TankHitDamageModifierCoop float 1.0 Damage dealt by Tanks is multiplied by this number in non PvP modes.
TankRunSpawnDelay float 15 in seconds (mutation19.nut Taaannnkk!)
Confirm:In proper category, and still working? Used in dash
WanderingZombieDensityModifier float 0.027 for versus, 0.03 otherwise Multiplier for the amount of wandering infected.
WaterSlowsMovement bool true The campaign "The Sacrifice" manually places trigger_playermovement in some of its maps's water.
ZombieDiscardRange int 2500 Any CI beyond this point will be deleted, while any AI-controlled SI will suicide.
ZombieDontClear bool false Do not mark nav areas as cleared.
ZombieSpawnInFog bool false Allows zombies to spawn in in line-of-sight of survivors in fogged areas.
ZombieSpawnRange float 1500.0 Maximum distance from the survivors that the infected can spawn.
ZombieTankHealth float 4000.0 Sets the amount of health a tank spawns with. The health is later affected by hidden health modifiers:

  • Easy? - x0.75
  • Advanced?, Expert? - x2
  • Versus modes? - x1.5

Spawning limits

Warning.pngWarning:Only the limits for bosses affect spawners.
Name Type Default value Description
BileMobSize int Number of commons spawned in a mob when a bile bomb is thrown or a survivor is hit by vomit. Also controls the common limit if a survivor is currently vomited on. Only works if either scripted mode is enabled or the finale is active. Found in the Dead Center and The Passing finales.
Note.pngNote:The common limit is not changed if the finale is a gauntlet finale.
BoomerLimit int 1 Maximum number of Boomers allowed to be in play simultaneously.
ChargerLimit int 1 Maximum number of chargers allowed to be in play simultaneously.
CommonLimit int 30 Maximum number of commons allowed to be in play simultaneously.
DominatorLimit int 2 Maximum number of dominator SI types (Hunter, Smoker, Jockey or Charger) that can freely fill up their caps. The extra SI type (3rd by default) will be capped at 1 regardless of its individual limit orcm_BaseSpecialLimit. Therefore, ifcm_BaseSpecialLimit = 2,MaxSpecials = 8andDominatorLimitis unset, the maximum amount of dominators will be 2+2+1+0. The remaining 3 slots could only be filled with Boomers and Spitters. Its maximum effective value is 4 since there are only 4 dominator types. To block all dominators, set it to -1.
HunterLimit int 1 Maximum number of Hunters allowed to be in play simultaneously.
JockeyLimit int 1 Maximum number of Jockeys allowed to be in play simultaneously.
MaxSpecials int 2 Maximum number of Director spawned Special Infected allowed to be in play simultaneously.
MegaMobSize int 50 The amount of total infected spawned during a panic event.
MobMaxPending int -1 How many infected can be left pending to spawn when the mob size is larger than CommonLimit.
MobMaxSize int 30 Maximum amount of infected that can spawn in a mob.
MobMinSize int 10 Minimum amount of infected that can spawn in a mob.
MobSpawnSize int -none- Static amount of infected in a mob. Overrides MobMinSize and MobMaxSize.
PreTankMobMax int 50
Confirm:In proper category, and still working? Possibly Gauntlet finale specific?
SmokerLimit int 1 Maximum number of Smokers allowed to be in play simultaneously.
SpitterLimit int 1 Maximum number of Spitters allowed to be in play simultaneously.
TankLimit int -1 Maximum number of Tanks allowed to be in play simultaneously.
WitchLimit int -1 Maximum number of Witches allowed to be in play simultaneously. Less than 0 means no maximum.

EMS Stage Specific

[Todo]

See L4D2_EMS/Appendix:_Spawning_Infected

Name Type Default value Description
AddToSpawnTimer float 0.0
Todo: needs more testing but it's related to adding time to special timers when stage changes
AllowCrescendoEvents bool true
PanicSpecialsOnly bool false The Panic should end when we finish with Specials, not wait for the MegaMob.
PanicWavePauseMax float
Todo: confirm category/working
PanicWavePauseMin float
Todo: confirm category/working
ScriptedStageType int 9 The type of stage to run next. See L4D2_EMS/StageTypeAppendix for a description of stage types.
ScriptedStageValue int 1 Dependant on the stage type.
SpawnDirectionCount int 0
Todo: confirm category/working
SpawnDirectionMask int 0 A bitfield (using SPAWNDIR_N, _NE, _E, etc) of directors to spawn from _relative to_ a map entity named Compass in your map. Designed for Survival-like game modes. See L4D2_EMS/Appendix:_Spawning_Infected.
SpawnSetPosition Vector The center point of the area infected can spawn in, when SpawnSetRule is set to SPAWN_POSITIONAL.
SpawnSetRadius float 1000.0 How far from the center point infected can spawn, when SpawnSetRule is set to SPAWN_POSITIONAL.
SpawnSetRule int 0 Overrides the mode of spawning used. Seems to be non-functional in finales. Valid flags are: SPAWN_ANYWHERE, SPAWN_FINALE, SPAWN_BATTLEFIELD, SPAWN_SURVIVORS, SPAWN_POSITIONAL
TotalBoomers int 0 Number of Boomers allowed in a wave.
TotalChargers int 0 Number of Chargers allowed in a wave.
TotalHunters int 0 Number of Hunters allowed in a wave.
TotalJockeys int 0 Number of Jockeys allowed in a wave.
TotalSmokers int 0 Number of Smokers allowed in a wave.
TotalSpecials int 0 Total number of Special Infected allowed in a wave.
TotalSpitters int Number of Spitters allowed in a wave.

Finale Specific/Related

A normal finale consists of X number of stages. Some variables in DirectorOptions can only be used during finales. Multiple custom finales can be defined in the same script, with the Options starting with A_, B_, C_, D_, E_. Which finale is used will be chosen randomly.

Name Type Default value Description
[A-E]_CustomFinale_StageCount int -none- Number of stages. Needs to be set for Versus scoring to function properly.
[A-E]_CustomFinaleX int -none- Stage type (enumerated PANIC, SCRIPTED (AKA ONSLAUGHT), DELAY, TANK), where X is the corresponding stage number. Usable in scripted panic events.
[A-E]_CustomFinaleValueX any -none- Value depends on the stage type above. Usable in scripted panic events.
[A-E]_CustomFinaleMusicX string -none- Soundscript entry to play. For instance, A_CustomFinaleMusic1 = "C2M5.BadManTank2" will play a Dark Carnival - Concert finale song. Does not work in Scripted Panic Events.
Note.pngNote:Dark Carnival - Concert finale does not use this method! It instead uses map logic and ambient_music. However its finale script hasA_CustomFinaleMusic4= "", suggesting that it may be disabling the default Tank music.
EnforceFinaleNavSpawnRules bool true Possibly used to enforce the finale spawning behavior without running a finale.
Todo: confirm category/working
HordeEscapeCommonLimit int -1 Number of commons allowed in the escape stage.
EscapeSpawnTanks bool true Whether to spawn tanks in the escape sequence.
Todo: possibly EMS stage related
MinimumStageTime float 1.0 The minimum amount of time a SCRIPTED stage is allowed to run before ending. Unavailable for Scripted Panic Events.

Gauntlet Specific/Related

These options are specific to Gauntlet finales. Most of these can be found in director_gauntlet.nut

Name Type Default value Description
CustomTankKiteDistance float 3000.0 Controls when the Gauntlet's Tank wave should start if a survivor advanced this far, in flow distance.
Movement Bonus related options
Movement Bonus are an unique RELAX pacing method present only in Gauntlet finales. Everytime the Movement Timer finishes its timing, Movement Bonus is incremented by its set value. However if a new mob spawns, the Director initiates an extra variable afterwards: Current Bonus. Current Bonus is a timer that lasts as long as the current Movement Bonus, which when still ticking down, disallows the Director from spawning any new infecteds (except Tanks).

To familiarize with Movement Bonus better, usedirector_debug 1in-game to see the values.

Name Type Default value Description
GauntletMovementThreshold float 500.0 When survivors advance this many amount of flow distance, from the last reset point or the start point, Movement Bonus, Movement Timer and Current Bonus is reset to defaults.
GauntletMovementTimerLength float 5.0 The interval between each Movement Bonus increase, in seconds.
GauntletMovementBonus float 2.0 The initial value, and the amount the movement Bonus increases everytime the timer stops, in seconds.
GauntletMovementBonusMax float 30.0 The maximum value that the Movement Bonus can store.

Versus Specific

Name Type Default value Description
TankHitDamageModifierVersus float 1.0 Damage dealt by Tanks is multiplied by this number in PvP modes.
ZombieGhostDelayMax float 30.0 Maximum time in seconds until allowing player infected to respawn.
ZombieGhostDelayMin float 20.0 Minimum time in seconds until allowing player infected to respawn.

Scavenge Specific/Related

Name Type Default value Description
ScavengeClusterBonusTime float 15.0
Todo: confirm category/working
ScavengeRoundInitialTime float 90.0 The timer's initial length when the round starts.
ScavengeScoreBonusTime float 15.0 Amount of time added to the timer when a gascan is successfully poured.

Survival Specific/Related

Name Type Default value Description
SurvivalSetupTime float (Used in mutation15.nut for Survival Versus with setup time of 90 seconds)

Mutation Specific/Related

Some of these values are mutation specific values of the global ones (cm_CommonLimit,cm_MaxSpecials, etc.), so use them if you are making a mutation, in case any map scripts are changing the global values.

Note.pngNote:These options need scripted mode to be active (e.g. running a mutation)
Name Type Default value Description
ActiveChallenge bool false Activates mutation mode.
Note.pngNote:Seems to be obsolete with the EMS update.
AllowWitchesInCheckpoints bool false Whether Witches are allowed to access nav areas marked with CHECKPOINT.
cm_AggressiveSpecials bool false If enabled, Special Infected will always go straight after the Survivors instead of possibly waiting around.
cm_AllowPillConversion bool true Allows pills to be converted to health kits or defibrillators in non-Expert difficulties.
cm_AllowSurvivorRescue bool true if base mode is coop, false otherwise Controls whether survivors can be respawned in rescue closets.
cm_AutoReviveFromSpecialIncap bool false Instantly revives a survivor when incapacitated by a Special Infected.
Note.pngNote:Doesn't work if a player isn't incapacitated by being dominated.
cm_AutoSpawnInfectedGhosts bool false
cm_BaseCommonAttackDamage float 1.0
cm_BaseSpecialLimit int Controls the default max limits of all the Special Infected.
Note.pngNote:Overridden by individual special limits. See https://github.com/Tsuey/L4D2-Community-Update/issues/317.
cm_CommonLimit int Identical to theCommonLimit key, except this key will be prioritized over anyCommonLimitkeys.
cm_FirstManOut bool false Ends the escape when the first survivor reaches the escape vehicle.
cm_HeadshotOnly bool false Every infected only takes damage when shot to the head, else they will only stumble. Tanks are excepted from this. Used in the mutation "Headshot!"
cm_HealingGnome bool false All survivors start with only temporary health, with a gnome to be picked up near of them; The gnome will slowly regenerate the health of anyone who holds it. Used in the mutation "Healing Gnome."
cm_InfiniteFuel bool false (mutation7.nut Chainsaw Massacre)
cm_MaxSpecials int -none- Identical to theMaxSpecials key, except this key will be priortized over anyMaxSpecialskeys.
cm_NoSurvivorBots bool false Should survivor bots be kicked on round start?
Todo: Improve description, add side effects
cm_ProhibitBosses bool -none- Identical to theProhibitBosses key, except this key will be priortized over anyProhibitBosseskeys.
cm_ShouldEscortHumanPlayers bool
cm_ShouldHurry bool false Prompt survivor bots to rush as they would in Versus.
cm_SingleScavengeCluster bool false Only a group of scavenge cans together will be active at once. Used in the mutation "Follow the Liter."
cm_SpecialRespawnInterval int -none- Identical to theSpecialRespawnInterval key, except this key will be priortized over anySpecialRespawnIntervalkeys.
cm_SpecialSlotCountdownTime int Used in Hunting Party (mutation16.nut).
Todo: Is this the same ascm_SpecialRespawnInterval?
cm_SpecialsRetreatToCover bool false
cm_TankLimit int -none- Identical to theTankLimit key, except this key will be priortized over anyTankLimitkeys.
cm_TankRun bool false Allows bypassing c7m1's second train door. Used in Taaannnkk! (mutation19.nut) and Tank Run mutations.
cm_TempHealthOnly bool false
cm_VIPTarget bool false Spawns a gnome in the safe area of each map that must be carried to the end of the map. Used in the mutation "Last Gnome on Earth"
cm_WanderingZombieDensityModifier float 0.027 for versus, 0.03 otherwise Identical to theWanderingZombieDensityModifier key, except this key will be priortized over anyWanderingZombieDensityModifierkeys.
cm_WitchLimit int -none- Identical to theWitchLimit key, except this key will be priortized over anyWitchLimitkeys.
NoMobSpawns bool false Prevents new mobs from attempting to spawn. Does not reset the timer, and already pending infected still spawn.
TempHealthDecayRate float 0.27 0.27 is the pain_pills_decay_rate default, higher values equals quicker decay.
Icon-Important.pngImportant:If you add this to your MutationOptions don't delete it later in an attempt to get back to defaults. This option directly changes pain_pills_decay_rate cvar and is the only proper way to change that cvar dynamically.

Callback Functions

When functions with these specific names are placed in the DirectorOptions table, they get called by C++ with specific arguments used.

Scripted mode callbacks

Function Signature Description
AllowFallenSurvivorItem bool AllowFallenSurvivorItem(string classname) For the given weapon classnames, return true to allow Fallen Survivors to carry the item, false / none is otherwise.
AllowWeaponSpawn bool AllowWeaponSpawn(string classname) Return false to the given string to disallow the respective weapon from spawning, used by several mutations.
ConvertWeaponSpawn string ConvertWeaponSpawn(string classname) For the given weapon classname, return another classname to convert the weapon to another, used by several mutations.
ConvertZombieClass int ConvertZombieClass(int infectedClass) Converts player-controlled Special Unfecteds into another. Used by the Taaannnk!! (mutation19.nut) and Riding My Survivor (community3.nut) mutations.
EndScriptedMode int EndScriptedMode() Called when the game attempts to end a round to allow changing the mission lost scenario or even preventing it. Used by the Dash mutation.
GetDefaultItem string GetDefaultItem(int index) Repeatedly called with incrementing indices. Return a string of a weapon name to make it a default item for survivors, or 0 to end the iteration.
ShouldAvoidItem bool ShouldAvoidItem(string classname) Return true or false to the given weapon classname to either make bots dislike or prefer a weapon. Used in mutations such as Four Swordsmen (mutation5.nut) or Chainsaw Massacre (mutation7.nut).
ShouldPlayBossMusic bool ShouldPlayBossMusic(int index) Whether the standard Tank music (Event.Tank) should be force played in a Tank fight. Normally, the standard Tank music is only played before finales and the finale variants (Event.TankMidpoint and Event.TankBrothers) only played during Tank stages (specifically FINALE_FINAL_BOSS for the second variant). Returning true will override the finale Tank music variant in Tank stages and also allow the standard Tank music in other stages. Returning false will silence the music even outside finales.
Todo: What is the index?

Internal callbacks

Warning.pngWarning:The following are internal/technical callbacks that should not be used directly by users.
Function Signature Description
OnChangeFinaleStage void OnChangeFinaleStage(int finaletype, int stagetype) Called right before OnBeginCustomFinaleStage. finaletype refers to the trigger_finale's Finale Type keyvalue. stagetype follows the special, FINALE_ prefixed, enumeration. It is used by director_base.nut to set the default music for finale stages by modifying the variable OnChangeFinaleMusic. As such, it's only called for stages without a _CustomFinaleMusic and is unsuitable for general use.

Data mining

The following are data mined Director options that may have never been functional in-game.

Name Type Default value Description
cm_AllowTeamSwap bool true

Enumerations

List of enumerations from DirectorScript table. If you have a script that intends to access these but won't be ran with the info_director's inputs, access them in this manner to avoid errors: DirectorScript.ALLOW_BASH_ALL.

Some enumerations here are bitmasked, so they can be combined with other ones. Any hook / callback functions are stylized in italics.

Note.pngNote:These aren't actual Squirrel enumerations, but rather table slots dressed up like constants.
AllowBash
  • ALLOW_BASH_ALL = 0
  • ALLOW_BASH_PUSHONLY = 1
  • ALLOW_BASH_NONE = 2
CTerrorPlayer::GetSenseFlags or CTerrorPlayer::SetSenseFlags (Bitmasks)
  • BOT_CANT_SEE = 1
  • BOT_CANT_HEAR = 2
  • BOT_CANT_FEEL = 4
CommandABot
  • BOT_CMD_ATTACK = 0
  • BOT_CMD_MOVE = 1
  • BOT_CMD_RETREAT = 2
  • BOT_CMD_RESET = 3
BotQuery
  • BOT_QUERY_NOTARGET = 1
CBaseEntity::TakeDamage or AllowTakeDamage (Bitmasks)
  • DMG_BULLET = 2
  • DMG_BURN = 8
  • DMG_BLAST = 64 (0x40)
  • DMG_MELEE = 2097152 (0x200000) (also known as DMG_SLOWBURN in other Source games)
  • DMG_STUMBLE = 33554432 (0x2000000)
  • DMG_BLAST_SURFACE = 134217728 (0x8000000)
  • DMG_BUCKSHOT = 536870912 (0x20000000)
  • DMG_HEADSHOT = 1073741824 (0x40000000)
DirectorOptions.OnChangeFinaleStage
  • FINALE_GAUNTLET_1 = 0
  • FINALE_HORDE_ATTACK_1 = 1
  • FINALE_HALFTIME_BOSS = 2
  • FINALE_GAUNTLET_2 = 3
  • FINALE_HORDE_ATTACK_2 = 4
  • FINALE_FINAL_BOSS = 5
  • FINALE_HORDE_ESCAPE = 6
  • FINALE_CUSTOM_PANIC = 7
  • FINALE_CUSTOM_TANK = 8
  • FINALE_CUSTOM_SCRIPTED = 9
  • FINALE_CUSTOM_DELAY = 10
  • FINALE_CUSTOM_CLEAROUT = 11
  • FINALE_GAUNTLET_START = 12
  • FINALE_GAUNTLET_HORDE = 13
  • FINALE_GAUNTLET_HORDE_BONUSTIME = 14
  • FINALE_GAUNTLET_BOSS_INCOMING = 15
  • FINALE_GAUNTLET_BOSS = 16
  • FINALE_GAUNTLET_ESCAPE = 17
Ticker_AddToHud
FLAGS
  • HUD_FLAG_PRESTR = 1
  • HUD_FLAG_POSTSTR = 2
  • HUD_FLAG_BEEP = 4
  • HUD_FLAG_BLINK = 8
  • HUD_FLAG_AS_TIME = 16
  • HUD_FLAG_COUNTDOWN_WARN = 32
  • HUD_FLAG_NOBG = 64
  • HUD_FLAG_ALLOWNEGTIMER = 128
  • HUD_FLAG_ALIGN_LEFT = 256
  • HUD_FLAG_ALIGN_CENTER = 512
  • HUD_FLAG_ALIGN_RIGHT = 768
  • HUD_FLAG_TEAM_SURVIVORS = 1024
  • HUD_FLAG_TEAM_INFECTED = 2048
  • HUD_FLAG_TEAM_MASK = 3072
  • HUD_FLAG_NOTVISIBLE = 16384
SLOTS
  • HUD_LEFT_TOP = 0
  • HUD_LEFT_BOT = 1
  • HUD_MID_TOP = 2
  • HUD_MID_BOT = 3
  • HUD_RIGHT_TOP = 4
  • HUD_RIGHT_BOT = 5
  • HUD_TICKER = 6
  • HUD_FAR_LEFT = 7
  • HUD_FAR_RIGHT = 8
  • HUD_MID_BOX = 9
  • HUD_SCORE_TITLE = 10
  • HUD_SCORE_1 = 11
  • HUD_SCORE_2 = 12
  • HUD_SCORE_3 = 13
  • HUD_SCORE_4 = 14
SPECIAL
  • HUD_SPECIAL_TIMER0 = 0
  • HUD_SPECIAL_TIMER1 = 1
  • HUD_SPECIAL_TIMER2 = 2
  • HUD_SPECIAL_TIMER3 = 3
  • HUD_SPECIAL_COOLDOWN = 4
  • HUD_SPECIAL_ROUNDTIME = 5
  • HUD_SPECIAL_MAPNAME = 6
  • HUD_SPECIAL_MODENAME = 7
ClientPrint
  • HUD_PRINTNOTIFY = 1
  • HUD_PRINTCONSOLE = 2
  • HUD_PRINTTALK = 3
  • HUD_PRINTCENTER = 4
DirectorOptions.InfectedFlags or ReapplyInfectedFlags (Bitmasks)
  • INFECTED_FLAG_CANT_SEE_SURVIVORS = 8192 (0x2000)
  • INFECTED_FLAG_CANT_HEAR_SURVIVORS = 16384 (0x4000)
  • INFECTED_FLAG_CANT_FEEL_SURVIVORS = 32768 (0x8000)
CTerrorPlayer::GetButtonMask (Bitmasks)
  • IN_ATTACK = 1
  • IN_JUMP = 2
  • IN_DUCK = 4
  • IN_FORWARD = 8
  • IN_BACK = 16 (0x10)
  • IN_USE = 32 (0x20)
  • IN_CANCEL = 64 (0x40)
  • IN_LEFT = 512 (0x200)
  • IN_RIGHT = 1024 (0x400)
  • IN_ATTACK2 = 2048 (0x800)
  • IN_RELOAD = 8192 (0x2000)
TerrorNavArea or CNavLadder
  • LADDER_UP = 0
  • LADDER_DOWN = 1
TerrorNavArea or CNavLadder
  • NAV_NORTH = 0
  • NAV_EAST = 1
  • NAV_SOUTH = 2
  • NAV_WEST = 3
DirectorOptions.SpawnSetRule
  • SCRIPTED_SPAWN_FINALE = 0
  • SCRIPTED_SPAWN_SURVIVORS = 1
  • SCRIPTED_SPAWN_BATTLEFIELD = 2
  • SCRIPTED_SPAWN_POSITIONAL = 3
DirectorOptions.SpawnSetRule
  • SPAWN_FINALE = 0
  • SPAWN_SURVIVORS = 1
  • SPAWN_BATTLEFIELD = 2
  • SPAWN_POSITIONAL = 3
SCRIPT_SHUTDOWN
Todo: Are these for the VS 2010 debugger?
  • SCRIPT_SHUTDOWN_MANUAL = 0
  • SCRIPT_SHUTDOWN_ROUND_RESTART = 1
  • SCRIPT_SHUTDOWN_TEAM_SWAP = 2
  • SCRIPT_SHUTDOWN_LEVEL_TRANSITION = 3
  • SCRIPT_SHUTDOWN_EXIT_GAME = 4
DirectorScript.SpawnDirectionMask (Bitmasks)
  • SPAWNDIR_N = 1
  • SPAWNDIR_NE = 2
  • SPAWNDIR_E = 4
  • SPAWNDIR_SE = 8
  • SPAWNDIR_S = 16 (0x10)
  • SPAWNDIR_SW = 32 (0x20)
  • SPAWNDIR_W = 64 (0x40)
  • SPAWNDIR_NW = 128 (0x80)
DirectorOptions.PreferredMobDirection or DirectorOptions.PreferredSpecialDirection
  • SPAWN_NO_PREFERENCE = -1
  • SPAWN_ANYWHERE = 0
  • SPAWN_BEHIND_SURVIVORS = 1
  • SPAWN_NEAR_IT_VICTIM = 2
  • SPAWN_SPECIALS_IN_FRONT_OF_SURVIVORS = 3
  • SPAWN_SPECIALS_ANYWHERE = 4
  • SPAWN_FAR_AWAY_FROM_SURVIVORS = 5
  • SPAWN_ABOVE_SURVIVORS = 6
  • SPAWN_IN_FRONT_OF_SURVIVORS = 7
  • SPAWN_VERSUS_FINALE_DISTANCE = 8
  • SPAWN_LARGE_VOLUME = 9
  • SPAWN_NEAR_POSITION = 10
DirectorOptions.ScriptedStageType
  • STAGE_PANIC = 0
  • STAGE_TANK = 1
  • STAGE_DELAY = 2
  • STAGE_CLEAROUT = 4
  • STAGE_SETUP = 5
  • STAGE_ESCAPE = 7
  • STAGE_RESULTS = 8
  • STAGE_NONE = 9
TraceLine (Bitmasks)
Todo: Is this a bitmask or what? If yes, then the term's definition in the second paragraph should be revised as these can't be independently combined.
  • TRACE_MASK_ALL = -1
  • TRACE_MASK_VISION = 33579073
  • TRACE_MASK_VISIBLE_AND_NPCS = 33579137
  • TRACE_MASK_PLAYER_SOLID = 33636363
  • TRACE_MASK_NPC_SOLID = 33701899
  • TRACE_MASK_SHOT = 1174421507
HUDManageTimers
  • TIMER_DISABLE = 0
  • TIMER_COUNTUP = 1
  • TIMER_COUNTDOWN = 2
  • TIMER_STOP = 3
  • TIMER_SET = 4
CTerrorPlayer::GiveUpgrade
  • UPGRADE_INCENDIARY_AMMO = 0
  • UPGRADE_EXPLOSIVE_AMMO = 1
  • UPGRADE_LASER_SIGHT = 2
ZSpawn
  • ZOMBIE_NORMAL = 0
  • ZOMBIE_SMOKER = 1
  • ZOMBIE_BOOMER = 2
  • ZOMBIE_HUNTER = 3
  • ZOMBIE_SPITTER = 4
  • ZOMBIE_JOCKEY = 5
  • ZOMBIE_CHARGER = 6
  • ZOMBIE_WITCH = 7
  • ZOMBIE_TANK = 8
  • ZSPAWN_MOB = 10
  • ZSPAWN_MUDMEN = 12
  • ZSPAWN_WITCHBRIDE = 11

See also

Intros

Documentations

Miscelleanous