mirror of
https://github.com/webbukkit/dynmap.git
synced 2025-01-26 01:21:29 +01:00
Merge pull request #3431 from BrainStone/fix-typeid
Fix issue with getting the type id of a block
This commit is contained in:
commit
e3fd4250ba
@ -15,6 +15,7 @@ import java.util.concurrent.Callable;
|
|||||||
import java.util.concurrent.CancellationException;
|
import java.util.concurrent.CancellationException;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
import org.bstats.bukkit.Metrics;
|
import org.bstats.bukkit.Metrics;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@ -172,6 +173,32 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Nonblocking thread safety
|
||||||
|
private static final AtomicBoolean tryNativeId = new AtomicBoolean(true);
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
private static final int getBlockIdFromMaterial(Material material) {
|
||||||
|
if (tryNativeId.get()) {
|
||||||
|
try {
|
||||||
|
return material.getId();
|
||||||
|
} catch (NoSuchMethodError e) {
|
||||||
|
// We failed once, no need to retry
|
||||||
|
tryNativeId.set(false);
|
||||||
|
} catch (java.lang.IllegalArgumentException e) {
|
||||||
|
// Ignore this entirely, as modern materials throw
|
||||||
|
// java.lang.IllegalArgumentException: Cannot get ID of Modern Material
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// We're living in a world where numerical IDs have been phased out completely.
|
||||||
|
// Let's return *some* number, because we need one.
|
||||||
|
// Also in that case we are adding a constant to ensure we're not conflicting with the
|
||||||
|
// actual IDs
|
||||||
|
return material.ordinal() + (1 << 20);
|
||||||
|
}
|
||||||
|
private static final int getBlockIdFromBlock(Block block) {
|
||||||
|
return getBlockIdFromMaterial(block.getType());
|
||||||
|
}
|
||||||
|
|
||||||
private class BukkitEnableCoreCallback extends DynmapCore.EnableCoreCallbacks {
|
private class BukkitEnableCoreCallback extends DynmapCore.EnableCoreCallbacks {
|
||||||
@Override
|
@Override
|
||||||
public void configurationLoaded() {
|
public void configurationLoaded() {
|
||||||
@ -213,7 +240,7 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
public int getBlockIDAt(String wname, int x, int y, int z) {
|
public int getBlockIDAt(String wname, int x, int y, int z) {
|
||||||
World w = getServer().getWorld(wname);
|
World w = getServer().getWorld(wname);
|
||||||
if((w != null) && w.isChunkLoaded(x >> 4, z >> 4)) {
|
if((w != null) && w.isChunkLoaded(x >> 4, z >> 4)) {
|
||||||
return w.getBlockTypeIdAt(x, y, z);
|
return getBlockIdFromBlock(w.getBlockAt(x, y, z));
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -1186,7 +1213,7 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
World w = loc.getWorld();
|
World w = loc.getWorld();
|
||||||
if(!w.isChunkLoaded(loc.getBlockX()>>4, loc.getBlockZ()>>4))
|
if(!w.isChunkLoaded(loc.getBlockX()>>4, loc.getBlockZ()>>4))
|
||||||
continue;
|
continue;
|
||||||
int bt = w.getBlockTypeIdAt(loc);
|
int bt = getBlockIdFromBlock(w.getBlockAt(loc));
|
||||||
/* Avoid stationary and moving water churn */
|
/* Avoid stationary and moving water churn */
|
||||||
if(bt == 9) bt = 8;
|
if(bt == 9) bt = 8;
|
||||||
if(btt.typeid == 9) btt.typeid = 8;
|
if(btt.typeid == 9) btt.typeid = 8;
|
||||||
@ -1213,7 +1240,7 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
private void checkBlock(Block b, String trigger) {
|
private void checkBlock(Block b, String trigger) {
|
||||||
BlockToCheck btt = new BlockToCheck();
|
BlockToCheck btt = new BlockToCheck();
|
||||||
btt.loc = b.getLocation();
|
btt.loc = b.getLocation();
|
||||||
btt.typeid = b.getTypeId();
|
btt.typeid = getBlockIdFromBlock(b);
|
||||||
btt.data = b.getData();
|
btt.data = b.getData();
|
||||||
btt.trigger = trigger;
|
btt.trigger = trigger;
|
||||||
blocks_to_check_accum.add(btt); /* Add to accumulator */
|
blocks_to_check_accum.add(btt); /* Add to accumulator */
|
||||||
|
Loading…
Reference in New Issue
Block a user