mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-25 00:16:54 +00:00
Fix monitors being warped after a resize
Oh, this was a really nasty bug to reproduce. I'm not sure why - it's very simple - I guess I've only just seen screenshots of it, and never sat down to try myself. Reminder to actually report your bugs folks! In this case: 1. Place down three down three monitors and then a computer. 2. Display something on the monitor (monitor left paint a) is my go-to. 3. Break the middle monitor. We'd expect the left most monitor to be cleared, however it actually preserves the monitor contents, resizing (and skewing it) to fit on its new size! This is because we clear the server monitor, but never sync that over to the client, so the client monitor retains the old contents. To fix that, instead of nulling out the server monitor, we null out the underlying Terminal. This causes the change to be synced, fixing the bug.
This commit is contained in:
parent
4541decd40
commit
ab785a0906
@ -349,13 +349,15 @@ public class MonitorBlockEntity extends BlockEntity {
|
|||||||
// Either delete the current monitor or sync a new one.
|
// Either delete the current monitor or sync a new one.
|
||||||
if (needsTerminal) {
|
if (needsTerminal) {
|
||||||
if (serverMonitor == null) serverMonitor = new ServerMonitor(advanced, this);
|
if (serverMonitor == null) serverMonitor = new ServerMonitor(advanced, this);
|
||||||
} else {
|
|
||||||
serverMonitor = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the terminal's width and height and rebuild it. This ensures the monitor
|
// Update the terminal's width and height and rebuild it. This ensures the monitor
|
||||||
// is consistent when syncing it to other monitors.
|
// is consistent when syncing it to other monitors.
|
||||||
if (serverMonitor != null) serverMonitor.rebuild();
|
serverMonitor.rebuild();
|
||||||
|
} else {
|
||||||
|
// Remove the terminal from the serverMonitor, but keep it around - this ensures that we sync
|
||||||
|
// the (now blank) monitor to the client.
|
||||||
|
if (serverMonitor != null) serverMonitor.reset();
|
||||||
|
}
|
||||||
|
|
||||||
// Update the other monitors, setting coordinates, dimensions and the server terminal
|
// Update the other monitors, setting coordinates, dimensions and the server terminal
|
||||||
var pos = getBlockPos();
|
var pos = getBlockPos();
|
||||||
|
@ -55,6 +55,12 @@ public class ServerMonitor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
synchronized void reset() {
|
||||||
|
if (terminal == null) return;
|
||||||
|
terminal = null;
|
||||||
|
markChanged();
|
||||||
|
}
|
||||||
|
|
||||||
private void markChanged() {
|
private void markChanged() {
|
||||||
if (!changed.getAndSet(true)) TickScheduler.schedule(origin.tickToken);
|
if (!changed.getAndSet(true)) TickScheduler.schedule(origin.tickToken);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user