better locking of lighting and use correct method for relight without removing first

Fixes #847
This commit is contained in:
dordsor21 2021-01-13 17:24:14 +00:00
parent b066ca8349
commit 97209d5680
No known key found for this signature in database
GPG Key ID: 1E53E88969FFCF0B
4 changed files with 30 additions and 12 deletions

View File

@ -71,6 +71,7 @@ public class NMSRelighter implements Relighter {
private final int maxY; private final int maxY;
private final boolean calculateHeightMaps; private final boolean calculateHeightMaps;
private final ReentrantLock lightingLock; private final ReentrantLock lightingLock;
private final AtomicBoolean finished = new AtomicBoolean(false);
private boolean removeFirst; private boolean removeFirst;
public NMSRelighter(IQueueExtent<IQueueChunk> queue, boolean calculateHeightMaps) { public NMSRelighter(IQueueExtent<IQueueChunk> queue, boolean calculateHeightMaps) {
@ -99,6 +100,11 @@ public class NMSRelighter implements Relighter {
return lightingLock; return lightingLock;
} }
@Override
public boolean isFinished() {
return finished.get();
}
@Override public synchronized void removeAndRelight(boolean sky) { @Override public synchronized void removeAndRelight(boolean sky) {
removeFirst = true; removeFirst = true;
fixLightingSafe(sky); fixLightingSafe(sky);
@ -839,10 +845,12 @@ public class NMSRelighter implements Relighter {
} }
if (Settings.IMP.LIGHTING.ASYNC) { if (Settings.IMP.LIGHTING.ASYNC) {
queue.flush(); queue.flush();
finished.set(true);
} else { } else {
TaskManager.IMP.sync(new RunnableVal<Object>() { TaskManager.IMP.sync(new RunnableVal<Object>() {
@Override public void run(Object value) { @Override public void run(Object value) {
queue.flush(); queue.flush();
finished.set(true);
} }
}); });
} }
@ -873,6 +881,7 @@ public class NMSRelighter implements Relighter {
Fawe.imp().getPlatformAdapter().sendChunk(chunk.getOrCreateGet(), bitMask, true); Fawe.imp().getPlatformAdapter().sendChunk(chunk.getOrCreateGet(), bitMask, true);
iter.remove(); iter.remove();
} }
finished.set(true);
} }
}; };
if (Settings.IMP.LIGHTING.ASYNC) { if (Settings.IMP.LIGHTING.ASYNC) {

View File

@ -53,4 +53,9 @@ public class NullRelighter implements Relighter {
public ReentrantLock getLock() { public ReentrantLock getLock() {
return null; return null;
} }
@Override
public boolean isFinished() {
return true;
}
} }

View File

@ -70,6 +70,13 @@ public interface Relighter {
ReentrantLock getLock(); ReentrantLock getLock();
/**
* Returns true if the Relighter has been flushed
*
* @return true if finished
*/
boolean isFinished();
class SkipReason { class SkipReason {
public static final byte NONE = 0; public static final byte NONE = 0;
public static final byte AIR = 1; public static final byte AIR = 1;

View File

@ -1098,18 +1098,15 @@ public class EditSession extends PassthroughExtent implements AutoCloseable {
limit.set(originalLimit); limit.set(originalLimit);
try { try {
if (relighter != null && !(relighter instanceof NullRelighter)) { if (relighter != null && !(relighter instanceof NullRelighter)) {
// Only relight once! // Don't relight twice!
if (Settings.IMP.LIGHTING.DELAY_PACKET_SENDING && !relighter.getLock().tryLock()) { if (!relighter.isFinished() && relighter.getLock().tryLock()) {
relighter.getLock().lock(); try {
relighter.getLock().unlock();
} else {
if (Settings.IMP.LIGHTING.REMOVE_FIRST) { if (Settings.IMP.LIGHTING.REMOVE_FIRST) {
relighter.removeAndRelight(true); relighter.removeAndRelight(true);
} else { } else {
relighter.fixSkyLighting(); relighter.fixLightingSafe(true);
relighter.fixBlockLighting();
} }
if (Settings.IMP.LIGHTING.DELAY_PACKET_SENDING) { } finally {
relighter.getLock().unlock(); relighter.getLock().unlock();
} }
} }