Modding/Guidelines/Systems – Arma Reforger Category

From Bohemia Interactive Community
m (Fix typo)
m (Lou Montana moved page Arma Reforger:Systems to Category:Arma Reforger/Modding/Guidelines/Systems: Category for systems)
 
(2 intermediate revisions by the same user not shown)
Line 19: Line 19:
== Template ==
== Template ==


Systems in script are automatically registered and nothing more needs to be done but to override the <enforce inline>GetSystemPoint()</enforce> method in order to define where the system will be updated.
{{Feature|informative|See {{Link|https://community.bistudio.com/wikidata/external-data/arma-reforger/EnfusionScriptAPIPublic/Page_WorldSystems.html#WorldSystemDocs_SystemConfiguration|Doxygen World Systems documentation}}.}}
 
=== Component ===
 
<enforce>
class TAG_FooComponent : ScriptComponent
{
void Update(float timeSlice)
{
Print("Update FooComponent each frame");
}
 
protected void ConnectToFooSystem()
{
World world = GetOwner().GetWorld();
SCR_FooSystem updateSystem = SCR_FooSystem.Cast(world.FindSystem(SCR_FooSystem, ESystemPoint.Frame));
if (!updateSystem)
return;
 
updateSystem.Register(this);
}
 
protected void DisconnectFromFooSystem()
{
World world = GetOwner().GetWorld();
SCR_FooSystem updateSystem = SCR_FooSystem.Cast(world.FindSystem(SCR_FooSystem, ESystemPoint.Frame));
if (!updateSystem)
return;
 
updateSystem.Unregister(this);
}
}
</enforce>
 
=== System ===
 
<enforce>
class TAG_FooSystem : GameSystem
{
protected ref array<SCR_FooComponent> m_aComponents = {};
 
override protected ESystemPoint GetSystemPoint()
{
return ESystemPoint.Frame;
}
 
override protected void OnUpdate()
{
float timeSlice = GetWorld().GetTimeSlice();
 
foreach (FooComponent comp : m_aComponents)
{
comp.Update(timeSlice);
}
}
 
override protected void OnDiag(float timeSlice)
{
DbgUI.Begin("SCR_FooSystem");
 
DbgUI.Text("Items: " + m_aComponents.Count());
 
if (DbgUI.Button("Dump active components"))
{
foreach (SCR_FooComponent comp : m_aComponents)
{
Print(comp.GetOwner(), LogLevel.ERROR);
}
}
 
DbgUI.End();
}
 
void Register(SCR_FooComponent component)
{
if (!m_aComponents.Contains(component))
m_aComponents.Insert(component);
}
 
void Unregister(SCR_FooComponent component)
{
m_aComponents.RemoveItem(component);
}
}
</enforce>





Latest revision as of 20:50, 22 October 2025

A System is a standalone piece of code or process that takes care of one specific operation.

For instance, if entities are capable of shooting and reloading, one system should handle the shooting logic, while the other should handle the reloading logic.


The idea behind splitting the logic into multiple systems is as follows:

  • Clear Operations Order - with one glance at where the systems are registered, it is possible to see right away how and when they are run
  • Logic Separation - rather than doing everything each system is only responsible for one specific feature/operation
  • Parallelisation - grouping allows for potential easy parallelisation engine-side
    • depending on what the other places in the code do, thanks to separating the logic it is vastly easier to manage parallel code execution
    • rather than processing things in the ABC ABC ABC ABC order, it is easier to change order and process all As before moving to Bs and Cs (AAAA BBBB CCCC)
  • Performance - because the engine needs to search through the hierarchy when updating components/entities, whereas Systems prevent doing so.


Systems should be used when something needs to be updated periodically.


Template


Current Limitations

  • No replication - there is no replication involved in Systems for now. If RPC or replicated properties are needed, use entities/components
  • Script only - a scripted system can only reference another scripted system, not an engine one
  • No cycle setting - there is currently no way to define a system's period (e.g tick only every x seconds instead of each frame)

Pages in category "Arma Reforger/Modding/Guidelines/Systems"

This category contains only the following page.