In summary:
- green wire: chest -> pole -> station
- delete pole
- green wire: chest -> station
- undo
- green wire: chest -> pole -> station and chest -> station
Can you provide a real example when somebody marks segment for a deconstruction and then someone else cancels it without one of these players being a troll?kovarex wrote: Wed Mar 05, 2025 12:23 pm This is very sad, but after several days of making this change and making everything work, we realized it is all bad idea.
The reason is simple, when you mark poles for deconstruction, they get disconnected, and undo works great, but when you "unmark" things for deconstruction, like when someone else wants to cancel the deconstruction of a big area for example, the electric poles are still disconnected.
This is a show stopper, and all the works was basically wasted time.
For this reason, we will just keep this bug in the game, as there is no nice solution to it.
It is not only case of trolls, a player itself when using cancel deconstruction would be also affected as that would be a new action so it could not use wires from the undo.Hares wrote: Thu Mar 06, 2025 11:59 am Can you provide a real example when somebody marks segment for a deconstruction and then someone else cancels it without one of these players being a troll?
I got your point.boskid wrote: Thu Mar 06, 2025 12:00 pmIt is not only case of trolls, a player itself when using cancel deconstruction would be also affected as that would be a new action so it could not use wires from the undo.Hares wrote: Thu Mar 06, 2025 11:59 am Can you provide a real example when somebody marks segment for a deconstruction and then someone else cancels it without one of these players being a troll?
No. Even if we would allow digging in the undo action, a lot of undo related stuff depends on the order of applying actions and it could happen that there was record for wire removed but there was also record for wire added, then again removed and again added. Which record should be used? Other players interacting with shared world is also problematic for undo because the undo may be related to a state of the world that is not valid anymore and so undo may sometimes fail to apply. It could be that a single player could have an undo actions for "removed wire, then removed wire" applying to the same entity just because other player added a wire in betweenHares wrote: Thu Mar 06, 2025 12:08 pm Also, if the same player is unmarking for deconstruction, the wires info can be extracted from the undo history.
boskid wrote: Thu Mar 06, 2025 12:14 pm ... there was record for wire removed but there was also record for wire added, then again removed and again added. Which record should be used?
1/ Have 2 poles (left and right) connected with wireHares wrote: Thu Mar 06, 2025 12:23 pm Edit:
Alternative proposal. Save wires within entity marked for deconstruction, and still do not allow connecting it as long as it marked for deconstruction.
Fair point. Thanks, I didn't see it.boskid wrote: Thu Mar 06, 2025 12:34 pm Even if you would say this is artificial scenario, it is one of the most common scenarios because of the entity search order of returning entities: selecting entities to deconstruct will visit entities one by one, lets say in order (left then right) and cancel will do the same: will visit entities one by one (also left then right).
What rewiring are you referring to? Rewiring on entity removal, or rewiring at all? For me (advanced player) the 1st causes more problems than benefits, but I can clearly see this as a point of frustration for the new players. The 2nd is a crucial part of a game, and doing so will destroy circuit networks.boskid wrote: Thu Mar 06, 2025 12:34 pm There exists a "true" solution: get rid of the rewiring because that is what causes new wires not seen by the undo (ordering deconstruction of entity remembers wires going out of that entity but it is not aware of wires that will be added by rewire). I am not sure if getting rid of this feature would be considered a fix.