This article's documentation is for anything that uses the Source engine. Click here for more information.

Logic random outputs: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
m (Changed parameters of {{this is a}} to comply with the updated version. This action was performed by a bot.)
(Undo revision 490177 by CHILLMODEA (talk) intentional)
Tag: Undo
 
(7 intermediate revisions by 5 users not shown)
Line 1: Line 1:
<!-- When this page is updated to {{langsp}} or {{langsp}} instead of {{lang}}, please move {{this is a}} to the base page, as it is automatically translated. -->{{lang}}
{{LanguageBar}}
{{infotable
{{CD|CLogicRandomOutputs|file1=1}}
|logic_random_outputs
{{this is a|logical entity|name=logic_random_outputs|since=Alien Swarm}} {{also|{{mapbase}}{{gmod}}}} It randomly fires one of up to eight separate outputs. Use [[logic_case]] in older engine branches or if you need twice as many outputs.
|img=[[File:logic_random_outputs.png]]
|type=e0
|engine=2
|in={{as|since}}
}}
 
{{this is a|point entity|name=logic_random_outputs|since=Alien Swarm}} {{also|{{mapbase}}}} It randomly fires one of up to eight separate outputs. Use [[logic_case]] in older engine branches or if you need twice as many outputs.
{{bug|The numbering of the <code>OnTriggerChance</code> keyvalues is off by one: they start at 1 while the game expects them to start at 0.<sup>[https://github.com/perilouswithadollarsign/cstrike15_src/blob/f82112a2388b841d72cb62ca48ab1846dfcc11c8/game/server/logic_random_outputs.cpp#L70 code]</sup> This causes the keyvalues to not correspond to the expected outputs. See [[#FGD Code|below]] for a fix.<br>For example, the keyvalue <code>OnTriggerChance1</code> determines the chance of the <code>OnTrigger2</code> output. With this incorrect set of keyvalues, <code>OnTrigger1</code> is never fired and <code>OnTriggerChance8</code> does not correspond to any of the outputs.}}
{{bug|The numbering of the <code>OnTriggerChance</code> keyvalues is off by one: they start at 1 while the game expects them to start at 0.<sup>[https://github.com/perilouswithadollarsign/cstrike15_src/blob/f82112a2388b841d72cb62ca48ab1846dfcc11c8/game/server/logic_random_outputs.cpp#L70 code]</sup> This causes the keyvalues to not correspond to the expected outputs. See [[#FGD Code|below]] for a fix.<br>For example, the keyvalue <code>OnTriggerChance1</code> determines the chance of the <code>OnTrigger2</code> output. With this incorrect set of keyvalues, <code>OnTrigger1</code> is never fired and <code>OnTriggerChance8</code> does not correspond to any of the outputs.}}
{{bug|Entity seems to be entirely broken in {{hla|1}} modding tools.}}
__NOTOC__
__NOTOC__
==Keyvalues==
== Keyvalues ==
{{KV Targetname}}
{{KV|OnTrigger1 Chance|to=OnTrigger8 Chance|intn=OnTriggerChance1|intn2=OnTriggerChance8|float|Chance (from 0 to 1) of the OnTrigger1-8 output firing when this entity is triggered.}}
{{KV StartDisabled}}


{{KV|OnTrigger1 Chance|to=OnTrigger8 Chance|intn=OnTriggerChance1|intn2=OnTriggerChance8|float|Chance (from 0 to 1) of the OnTrigger1-8 output firing when this entity is triggered.}}
== Flags ==
{{KV EnableDisable}}
<!--{{KV BaseEntity}}
-->
==Flags==
{{fl|1|Only trigger once}}
{{fl|1|Only trigger once}}
{{fl|2|Allow fast retrigger}}
{{fl|2|Allow fast retrigger}}


==Inputs==
== Inputs ==
{{IO|Trigger|Trigger this entity, causing its OnTrigger outputs to fire if it is enabled.}}
{{I|Trigger|Trigger this entity, causing its OnTrigger outputs to fire if it is enabled.}}
{{IO|Toggle|Toggle this entity between enabled and disabled.}}
{{I|Toggle|Toggle this entity between enabled and disabled.}}
{{IO|CancelPending|Cancel any events fired by this entity that are currently pending in the I/O event queue.}}
{{I|CancelPending|Cancel any events fired by this entity that are currently pending in the I/O event queue.}}
{{I EnableDisable}}
{{I EnableDisable}}
<!--{{I BaseEntity}}
 
-->
==Outputs==
==Outputs==
{{IO|OnSpawn|Fired when this entity is spawned. If this entity is set to only trigger once, it will delete itself after firing this output.}}
{{O|OnSpawn|Fired when this entity is spawned. If this entity is set to only trigger once, it will delete itself after firing this output.}}
{{IO|OnTrigger1|to=OnTrigger8|This output has a chance to fire when the entity is triggered.}}
{{O|OnTrigger1|to=OnTrigger8|This output has a chance to fire when the entity is triggered.}}
<!--{{O BaseEntity}}
 
-->
 
==[[FGD]] Code==
== [[FGD]] Code ==
This code belongs to [[base.fgd]]. In the highlighted lines, the index of the KeyValue's name was decreased by 1 each but not their display text.
This code belongs to [[base.fgd]]. In the highlighted lines, the index of the KeyValue's name was decreased by 1 each but not their display text.
So that with this fix, the numbering of the KeyValues and outputs will match in [[Hammer]] such that mappers can act as if this bug didn't exist, as long as [[SmartEdit]] is turned on.
So that with this fix, the numbering of the KeyValues and outputs will match in [[Hammer]] such that mappers can act as if this bug didn't exist, as long as [[SmartEdit]] is turned on.

Latest revision as of 06:05, 10 October 2025

English (en)Translate (Translate)
C++ Class hierarchy
CLogicRandomOutputs
CLogicalEntity
CServerOnlyEntity
CBaseEntity
C++ logic_random_outputs.cpp

logic_random_outputs is a logical entity available in all Source Source games since Alien Swarm Alien Swarm. (also in MapbaseGarry's Mod) It randomly fires one of up to eight separate outputs. Use logic_case in older engine branches or if you need twice as many outputs.

Icon-Bug.pngBug:The numbering of the OnTriggerChance keyvalues is off by one: they start at 1 while the game expects them to start at 0.code This causes the keyvalues to not correspond to the expected outputs. See below for a fix.
For example, the keyvalue OnTriggerChance1 determines the chance of the OnTrigger2 output. With this incorrect set of keyvalues, OnTrigger1 is never fired and OnTriggerChance8 does not correspond to any of the outputs.  [todo tested in ?]
Icon-Bug.pngBug:Entity seems to be entirely broken in Half-Life: Alyx modding tools.  [todo tested in ?]

Keyvalues

Name (targetname) <string>[ Edit ]
The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentname or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

OnTrigger1 Chance (OnTriggerChance1) to OnTrigger8 Chance (OnTriggerChance8) <float>
Chance (from 0 to 1) of the OnTrigger1-8 output firing when this entity is triggered.
Start Disabled (StartDisabled) <boolean>
Stay dormant until activated (with theEnableinput).

Flags

Only trigger once : [1]
Allow fast retrigger : [2]

Inputs

Trigger
Trigger this entity, causing its OnTrigger outputs to fire if it is enabled.
Toggle
Toggle this entity between enabled and disabled.
CancelPending
Cancel any events fired by this entity that are currently pending in the I/O event queue.

EnableDisable:

Enable / Disable
Enable/disable this entity from performing its task. It might also disappear from view.

Outputs

OnSpawn
Fired when this entity is spawned. If this entity is set to only trigger once, it will delete itself after firing this output.
OnTrigger1 to OnTrigger8
This output has a chance to fire when the entity is triggered.


FGD Code

This code belongs to base.fgd. In the highlighted lines, the index of the KeyValue's name was decreased by 1 each but not their display text. So that with this fix, the numbering of the KeyValues and outputs will match in Hammer such that mappers can act as if this bug didn't exist, as long as SmartEdit is turned on.

@PointClass base(Targetname, EnableDisable) iconsprite("editor/logic_random_outputs.vmt") = logic_random_outputs :
	"A message forwarder. Fires up to eight separate outputs, each with a different chance of firing."
[
	spawnflags(flags) =
	[
		1: "Only trigger once" : 0
		2: "Allow fast retrigger" : 0
	]
	OnTriggerChance0(float) : "OnTrigger1 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger1 output firing when this entity is triggered."
	OnTriggerChance1(float) : "OnTrigger2 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger2 output firing when this entity is triggered."
	OnTriggerChance2(float) : "OnTrigger3 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger3 output firing when this entity is triggered."
	OnTriggerChance3(float) : "OnTrigger4 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger4 output firing when this entity is triggered."
	OnTriggerChance4(float) : "OnTrigger5 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger5 output firing when this entity is triggered."
	OnTriggerChance5(float) : "OnTrigger6 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger6 output firing when this entity is triggered."
	OnTriggerChance6(float) : "OnTrigger7 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger7 output firing when this entity is triggered."
	OnTriggerChance7(float) : "OnTrigger8 Chance" : "1.0" : "Chance (from 0 to 1) of the OnTrigger8 output firing when this entity is triggered."

	// Inputs
	input Trigger(void) : "Trigger this entity, causing its OnTrigger outputs to fire if it is enabled."
	input Toggle(void) : "Toggle this entity between enabled and disabled."
	input CancelPending(void) : "Cancel any events fired by this entity that are currently pending in the I/O event queue."
	
	// Outputs
	output OnSpawn(void) : "Fired when this entity is spawned. If this entity is set to only trigger once, it will "+
		"delete itself after firing this output."
	output OnTrigger1(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger2(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger3(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger4(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger5(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger6(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger7(void) : "This output has a chance to fire when the entity is triggered."
	output OnTrigger8(void) : "This output has a chance to fire when the entity is triggered."
]