Page 1 of 1

on_combinator_recieve_circuit_update (changeable)

Posted: Fri Sep 13, 2019 8:09 pm
by LuziferSenpai
Hey,

is it possible to get a Event that triggers when a Combinator recieves a Circuit Network Update as Input?
This would be VERY helpful for Modifications like: And other.

How would the Event work?
It triggers everytime the Input of a Combinator Type Entity Updates.

Greetz,

Luzifer

Re: on_combinator_recieve_circuit_update (changeable)

Posted: Fri Sep 13, 2019 8:15 pm
by Rseding91
I realistically don't see this happening. That's essentially on_tick with some extra flare and quickly runs into performance concerns with firing the event too frequently.

Re: on_combinator_recieve_circuit_update (changeable)

Posted: Fri Sep 13, 2019 8:17 pm
by LuziferSenpai
The current Problem is that mostly every Modification named has a massiv UPS Problem, because we need to check each entity and that can lead to MASSIV Problems. So I was searching for a Way to fix this Problem.

Re: on_combinator_recieve_circuit_update (changeable)

Posted: Fri Sep 13, 2019 8:24 pm
by Rseding91
LuziferSenpai wrote: Fri Sep 13, 2019 8:17 pm The current Problem is that mostly every Modification named has a massiv UPS Problem, because we need to check each entity and that can lead to MASSIV Problems. So I was searching for a Way to fix this Problem.
Yes, what those mod(s) are trying to do is well outside of what the mod API was designed for and as such there's typically performance concerns.

Re: on_combinator_recieve_circuit_update (changeable)

Posted: Fri Sep 13, 2019 8:28 pm
by LuziferSenpai
Okay ...

Re: on_combinator_recieve_circuit_update (changeable)

Posted: Sat Sep 14, 2019 8:13 am
by mrvn
The problem I see here is that events are global and not bound to any entity. Even assuming you add a prototype flag "mod-circuit-update" so the event only triggers for special entities every time any one of possibly millions of such entities gets a changed input signal the event would trigger for all mods. Not just the mod that handles the entity with changes.

Secondly there is no rate limiting for
a) a million entities change input the same tick.

Mods might want to only process a handful entities each tick in a round-robin fashion and rather get slower response time instead of halting the game.

b) one entity changes input every tick.

Mods might only want to respond to changes every so often to save on processing time.


On the other hand how would this be worse? Currently all those mods do on_tick() and for each of their entities they get the signals, check if anything has changed and if so update the outputs. With the proposed signals worst case you still do basically on_tick. But now the event could have a table of entity with changes. So instead of the expensive callback to get the signals and comparing them you check if the table contains any entities you are responsible for. I can see a huge potential for saved time there.