mirror of
https://github.com/plexusorg/Plex-FAWE.git
synced 2024-09-19 13:58:22 +00:00
8c0195970b
* Consistenty use javax annotations. - Unfortunately jetbrains annotations seem to be exposed transitively via core somewhere, but with the correct IDE settings, annotations can be defaulted to javax - Cleaning up of import order in #1195 - Must be merged before #1195 * Add and apply .editorconfig from P2 - Does not rearrange entries * Address some comments * add back some javadoc comments * Address final comments Co-authored-by: NotMyFault <mc.cache@web.de>
42 lines
1.2 KiB
Java
42 lines
1.2 KiB
Java
package com.fastasyncworldedit.core.extent;
|
|
|
|
import com.fastasyncworldedit.core.Fawe;
|
|
import com.sk89q.worldedit.WorldEditException;
|
|
import com.sk89q.worldedit.extent.AbstractDelegateExtent;
|
|
import com.sk89q.worldedit.extent.Extent;
|
|
import com.sk89q.worldedit.world.block.BlockStateHolder;
|
|
|
|
public class SlowExtent extends AbstractDelegateExtent {
|
|
|
|
private final long THRESHOLD = 50 * 1000000; // 1 tick
|
|
private final long nanos;
|
|
private long increment;
|
|
|
|
public SlowExtent(Extent extent, long nanos) {
|
|
super(extent);
|
|
this.nanos = nanos;
|
|
}
|
|
|
|
@Override
|
|
public <T extends BlockStateHolder<T>> boolean setBlock(int x, int y, int z, T block) throws WorldEditException {
|
|
delay();
|
|
return super.setBlock(x, y, z, block);
|
|
}
|
|
|
|
public void delay() {
|
|
increment += nanos;
|
|
if (increment >= THRESHOLD) {
|
|
long wait = increment / 1000000;
|
|
if (!Fawe.isMainThread()) {
|
|
try {
|
|
Thread.sleep(wait);
|
|
} catch (InterruptedException e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
increment -= wait * 1000000;
|
|
}
|
|
}
|
|
|
|
}
|