-
Notifications
You must be signed in to change notification settings - Fork 104
Internals
Note: this page is constantly updated with the latest master build in mind
Effects have 3 functions which handle logic at different points of the lifecycle: OnStart, OnStop and OnTick. OnStart is called as soon as the effect is dispatched. OnStop is called as soon as the effect is about to be stopped, be it by the timer or the user. OnTick is called once each frame after OnStart has been called and before OnStop gets called.
The call chain looks like this for both timed and non-timed effects: OnStart -> OnTick -> OnStop Each call only occurs once per frame.
Non-timed and timed effects exhibit mostly the same behavior, with following differences:
- Timed effects have a user-visible effect timer next to the name
- Non-timed effects can be preemptively stopped, whilst timed ones will run the entire duration (as long as m_MaxRunningEffects is not reached)
WAIT calls will pause an effect for X duration (in milliseconds). WAIT calls will not affect anything other than the effect itself as they run in individual fibers (aka lightweight threads). They are allowed at any stage of the lifecycle, though if the user is either clearing all effects or disabling the mod the following occurs:
- The time passed to WAIT will be ignored; WAIT calls will behave as if X is always 0
- Your effect will be forcefully terminated if more than 20 WAIT calls occur in either OnStart or OnStop, potentially causing the effect's cleanup routine to not be executed
- This also occurs if the effect timer runs out and the effect dispatcher waited 60 seconds after sending a stop request to the effect's thread