Jump to content

The Prerequisite System: Difference between revisions

From ModEnc²
No edit summary
Rain-Islet (talk | contribs)
m [bot] Batch update {{Bugs}} templates.
 
(14 intermediate revisions by 8 users not shown)
Line 3: Line 3:
|
|
; Is this object's TechLevel valid?
; Is this object's TechLevel valid?
: Checks if the TechLevel of the object is above -1 and below [{{TTL|MultiplayerDialogSettings}}]→{{TTL|TechLevel}}.
: Checks if the TechLevel of the object is above -1 and below [{{f|MultiplayerDialogSettings|link}}]→{{f|TechLevel|link}}.
; Is this house not forbidden from owning this object?
; Is this house not forbidden from owning this object?
: Checks if the house is not listed in {{TTL|ForbiddenHouses}}.
: Checks if the house is not listed in {{f|ForbiddenHouses|link}}.
; Is this house allowed to own this object?
; Is this house allowed to own this object?
: Checks if the house is listed in {{TTL|RequiredHouses}}.
: Checks if the house is listed in {{f|RequiredHouses|link}}.
; Does this house own all the prerequisite structures?
; Does this house own all the prerequisite structures?
: Checks if the house owns the prerequisite structures listed in {{TTL|Prerequisite}}
: Checks if the house owns the prerequisite structures listed in {{f|Prerequisite|link}}
; Is this object stolen technology?{{yro}}
; Is this object stolen technology?{{yro}}
: If the unit contains {{TTL|RequiresStolenAlliedTech}}<tt>=yes</tt>, {{TTL|RequiresStolenSovietTech}}<tt>=yes</tt>, or {{TTL|RequiresStolenThirdTech}}<tt>=yes</tt>, has the apropriate lab get spied upon?
: If the unit contains {{f|RequiresStolenAlliedTech|link}}<tt>=yes</tt>, {{f|RequiresStolenSovietTech|link}}<tt>=yes</tt>, or {{f|RequiresStolenThirdTech|link}}<tt>=yes</tt>, has the apropriate lab get spied upon?
|}
|}
If all conditions are met, the house is ''theoretically allowed'' to build that object, signaled by a [[EVA_NewConstructionOptions|"New Construction Options"]] announcement.<br>
If all conditions are met, the house is ''theoretically allowed'' to build that object, signaled by a [[EVA_NewConstructionOptions|"New Construction Options"]] announcement.<br>
Line 17: Line 17:
:{|style="border: 1px solid #aaaaaa; background:#e5e5e5; border-spacing: 5px;"
:{|style="border: 1px solid #aaaaaa; background:#e5e5e5; border-spacing: 5px;"
|
|
; Does the house own a {{TTL|Factory}} of the appropriate type?
; Does the house own a {{f|Factory|link}} of the appropriate type?
: Checks whether the house has at least one structure with {{TTL|Factory}} matching the object's type.
: Checks whether the house has at least one structure with {{f|Factory|link}} matching the object's type.
; Can this house own this object?
; Can this house own this object?
: Checks if your {{TTL|Factory}} contains atleast 1 {{TTL|Owner}} listed as this units {{TTL|Owner}}.
: Checks if your {{f|Factory|link}} contains atleast 1 {{f|Owner|link}} listed as this units {{f|Owner|link}}.
; If the object in question is a VehicleType, does the house have a {{TTL|Factory|VehicleType}} with the same {{TTL|Naval}} setting as the object?
; If the object in question is a VehicleType, does the house have a {{f|Factory|VehicleType|link}} with the same {{f|Naval|link}} setting as the object?
: Checks whether the house has a War Factory if it's trying to build land-based ({{TTL|Naval|no}}) vehicles, and whether it has a Shipyard if it's trying to build water-based ({{TTL|Naval|yes}}) vehicles.
: Checks whether the house has a War Factory if it's trying to build land-based ({{f|Naval|no|link}}) vehicles, and whether it has a Shipyard if it's trying to build water-based ({{f|Naval|yes|link}}) vehicles.
|}
|}
'''Note:''' If you do not have the appropriate type of {{TTL|Factory|VehicleType}}, but all other prerequisites are fulfilled, you will probably experience the [[NCO-Bug]].


==Overrides==
==Overrides==
*If an object has a {{TTL|PrerequisiteOverride}} BuildingType (or multiple BuildingTypes) set, a house will be allowed to build the object as soon as it possesses any single one of those listed BuildingTypes, no matter what prerequisites the object usually requires. (Hence the name.)
*If an object has a {{f|PrerequisiteOverride|link}} BuildingType (or multiple BuildingTypes) set, a house will be allowed to build the object as soon as it possesses any single one of those listed BuildingTypes, no matter what prerequisites the object usually requires. (Hence the name.)
*The same applies to objects from a [[Building:Secret Lab|Secret Lab]]: If a house gains an object through a Secret Lab, it will be allowed to build that object immediately, no matter what prerequisites the object usually requires. Such an object will be buildable even if it has {{TTL|TechLevel|11}} set.
*The same applies to objects from {{f|SecretLab|yes|link}} buildings: If a house gains an object through a Secret Lab, it will be allowed to build that object immediately, no matter what prerequisites the object usually requires. Such an object will be buildable even if it has {{f|TechLevel|11|link}} set.
*In addition, AI players do not check {{TTL|Prerequisite}} and {{TTL|TechLevel}} tags when they're trying to build the Power Plants listed under {{TTL|GDIPowerPlant}}, {{TTL|NodRegularPower}}, {{TTL|ThirdPowerPlant}}{{yro}}.
*In addition, AI players do not check {{f|Prerequisite|link}} and {{f|TechLevel|link}} tags when they're trying to build the Power Plants listed under {{f|GDIPowerPlant|link}}, {{f|NodRegularPower|link}}, {{f|ThirdPowerPlant|link}}{{yro}}.
*AI players also ignore all {{TTL|Prerequisite}} settings except {{TTL|TechLevel}} on all other objects, they build objects in the order dictated by the {{Ini|ai}} file (the order of BuildingTypes is controlled by different methods covered [[AI base building|here]]).
*AI players also ignore all {{f|Prerequisite|link}} settings except {{f|TechLevel|link}} on all other objects, they build objects in the order dictated by the {{Ini|ai}} file (the order of BuildingTypes is controlled by different methods covered [[AI base building|here]]).
''All cases under the presumption that the house owns a factory of the appropriate type.''
''All cases under the presumption that the house owns a factory of the appropriate type.''


==Prerequisite Groups==
==Prerequisite Groups==
A "prerequisite group" refers to a list of structures, and any single one of them is sufficient to fulfill the "prerequisite group". The following "prerequisite groups" are valid:
A "prerequisite group" refers to a list of structures, and any single one of them is sufficient to fulfill the type. See: [[Generic Prerequisites]].
* POWER (corresponds to {{TTL|PrerequisitePower}})
* PROC (corresponds to {{TTL|PrerequisiteProc}} and {{TTL|PrerequisiteProcAlternate}}{{yro}})
* BARRACKS (corresponds to {{TTL|PrerequisiteBarracks}})
* FACTORY (corresponds to {{TTL|PrerequisiteFactory}})
* RADAR (corresponds to {{TTL|PrerequisiteRadar}})
* TECH (corresponds to {{TTL|PrerequisiteTech}})


In Firestorm, two additional groups were available:
=={{bugs}}==
Only one building specified by <tt>PrerequisiteOverride=</tt> activates production, meaning that it's not a cumulative list like <tt>Prerequisites=</tt>.
* Ares can allow more types of prerequisite alternatives, see: https://ares-developers.github.io/Ares-docs/new/prerequisites.html


* GDIFACTORY (corresponds to {{TTL|PrerequisiteGDIFactory}})
At least in {{ra2}} and {{yr}}, the AI players ignore <tt>Prerequisites=</tt> for building queues, limited instead by [[AIBuildThis]], [[Owner]], [[RequiredHouses]], [[ForbiddenHouses]], and stolen tech requirements.
* NODFACTORY (corresponds to {{TTL|PrerequisiteNodFactory}})
 
Also in {{ra2}}, the [[AITriggerTypes]] in {{ini|ai}} instruct the AI player to produce [[TaskForces]] disregarding <tt>Prerequisites</tt> altogether, as well as [[TechLevel]], limited by other factors as above.


[[Category: Systems]]
[[Category: Systems]]
==RP's 'NEW' Prerequisite System stuff{{rpo}}==
* <tt>NegativePrerequisite=</tt>
:If anything on this list is owned by the player, then the object <b>can't</b> be built.
* <tt>AlternatePrerequisite=</tt>
:A Clone of {{TTL|Prerequisite}}<tt>=</tt>, if all items on either {{TTL|Prerequisite}}<tt>=</tt>, or <tt>AlternatePrerequisite=</tt> are owned by the player, then the {{TTL|Prerequisite}}<tt>=</tt> condition is considered to be met. (on a side note, more of these clones are wanted)
* <tt>SovietAdvancedPower=</tt> RPCE only.
:Revival of {{TTL|NodAdvancedPower}}<tt>=</tt>, but with a new name so as to not conflict with the un-modded game, thereby not allowing the Soviets to build the Nuclear Reactor, which by default is not on that tag, instead the tag is set to NAAPWR, the TS Nod Advanced Power Plant. Basically this tag allows the Soviets to build their 'Advanced Power Plant' when they are low on power, instead of lots of regular Power Plants, as long as they meet the prerequisites for that Advanced Power Plant. in RP v1.10 this was replaced with the new PowerPlants= tag.
* <tt>PowerPlant=</tt>
:This is the new version of GDIPowerPlant=, NodRegularPower= and ThirdPowerPlant= listed under the sides header ([GDI], [Nod] and [ThirdSide] are the default 3). Although this is automaticly mapped to the original 3 tags for the original 3 sides, FourthPowerPlant is Obsolete.
* <tt>PowerPlants=</tt>
:This is a list of power plants per side under the sides header , which lists BuildingType that are randomly selected when that side requires extra power.
* <tt>RequiresStolenTech=</tt>
:New stolen tech logic based on {{TTL|RequiresStolenAlliedTech}}<tt>=yes</tt>, {{TTL|RequiresStolenSovietTech}}<tt>=yes</tt>, and {{TTL|RequiresStolenThirdTech}}<tt>=yes</tt>, which allows the modder to specify a new structure that needs to be spied upon to obtain this unit. the building you need to spy on also requires the tags <tt>IsStolenTech=yes</tt> and <tt>Spyable=yes</tt>
Note: Other items are currently planned, or wished for future RP versions, but only complete items belong on this list.

Latest revision as of 17:57, 2 July 2025

The Prerequisite System controls the conditions required to build a certain object. Those conditions are:

Is this object's TechLevel valid?
Checks if the TechLevel of the object is above -1 and below [MultiplayerDialogSettings]→TechLevel.
Is this house not forbidden from owning this object?
Checks if the house is not listed in ForbiddenHouses.
Is this house allowed to own this object?
Checks if the house is listed in RequiredHouses.
Does this house own all the prerequisite structures?
Checks if the house owns the prerequisite structures listed in Prerequisite
Is this object stolen technology?
If the unit contains RequiresStolenAlliedTech=yes, RequiresStolenSovietTech=yes, or RequiresStolenThirdTech=yes, has the apropriate lab get spied upon?

If all conditions are met, the house is theoretically allowed to build that object, signaled by a "New Construction Options" announcement.
Next, the game determines whether the house actually can build the object:

Does the house own a Factory of the appropriate type?
Checks whether the house has at least one structure with Factory matching the object's type.
Can this house own this object?
Checks if your Factory contains atleast 1 Owner listed as this units Owner.
If the object in question is a VehicleType, does the house have a Factory=VehicleType with the same Naval setting as the object?
Checks whether the house has a War Factory if it's trying to build land-based (Naval=no) vehicles, and whether it has a Shipyard if it's trying to build water-based (Naval=yes) vehicles.

Overrides

  • If an object has a PrerequisiteOverride BuildingType (or multiple BuildingTypes) set, a house will be allowed to build the object as soon as it possesses any single one of those listed BuildingTypes, no matter what prerequisites the object usually requires. (Hence the name.)
  • The same applies to objects from SecretLab=yes buildings: If a house gains an object through a Secret Lab, it will be allowed to build that object immediately, no matter what prerequisites the object usually requires. Such an object will be buildable even if it has TechLevel=11 set.
  • In addition, AI players do not check Prerequisite and TechLevel tags when they're trying to build the Power Plants listed under GDIPowerPlant, NodRegularPower, ThirdPowerPlant.
  • AI players also ignore all Prerequisite settings except TechLevel on all other objects, they build objects in the order dictated by the ai(md).ini file (the order of BuildingTypes is controlled by different methods covered here).

All cases under the presumption that the house owns a factory of the appropriate type.

Prerequisite Groups

A "prerequisite group" refers to a list of structures, and any single one of them is sufficient to fulfill the type. See: Generic Prerequisites.

Bugs/Side-Effects/Unexpected Limitations

Only one building specified by PrerequisiteOverride= activates production, meaning that it's not a cumulative list like Prerequisites=.

At least in Red Alert 2 and Yuri's Revenge, the AI players ignore Prerequisites= for building queues, limited instead by AIBuildThis, Owner, RequiredHouses, ForbiddenHouses, and stolen tech requirements.

Also in Red Alert 2, the AITriggerTypes in ai(md).ini instruct the AI player to produce TaskForces disregarding Prerequisites altogether, as well as TechLevel, limited by other factors as above.