Unsynchronized events
Staying in sync in multiplayer game
Unsynchronized events are not synchronized in multiplayer game as they are usually triggered only a local computer so the CON code doesn't have to work the same way on different computers. These events usually are display related or have effect only on the current computer.
Synchronized events always triggered on all computers at the same time and at the same conditions. These events triggers on specific ingame situations.
Random Numbers and Multiplayer Sync
In order to understand the interaction of random occurrences and unsynchronized events, you need to understand two things:
- randvar and ifrnd are NOT RANDOM. They step through a pre-determined sequence of numbers that appear to be random.
- In multiplayer, very little information is shared between the different computers.
Every time something "random" happens in the game, it must happen the same way on all of the computers. Since all of them start with the same number and go through the same sequence of numbers at the same times, everything works. But if one computer calls ifrnd or randvar while the others do not, it ends up at a different place in the random sequence. The next time something random happens in the game, it occurs differently on this computer, causing the game to become out-of-sync. (This isn't even the worst case: Imagine each computer on a wildly different place in the sequence.)
Unsynchronized events are not guaranteed to happen at the same time, or at all, between different computers in a multiplayer game. Therefore, it is not safe to use ifrnd or randvar in them, because they could end up out of sequence. It is also not safe to do anything affecting gameplay in these events for the same reason.
Displayrand is an exception because it does not affect the sequence used by the other commands. Therefore it is safe to use in unsynchronized events. It should not be used in other events because that would cause the same problems outlined above.
DO and DON'Ts
1. Do use randvar,randvarvar, ifrnd in synchronized events.
2. Do use displayrand, displayrandvar, displayrandvarvar in unsynchronized events.
3. Do not use randvar,randvarvar, ifrnd in unsynchronized events.
4. Do not use displayrand, displayrandvar, displayrandvarvar in synchronized events.
5. Do not collect information in unsynchronized events that later might be used in synchronized events or actors.
6. Do not use local vars(like user options) in synchronized events. The compiler will warn you about this(note: it won't if a local var is in a state).
7. Do not use gameplay related commands in unsynchronized events. The compiler will warn you about this(note: it won't if a local var is in a state).