mirror of
https://github.com/webbukkit/dynmap.git
synced 2024-11-24 19:25:15 +01:00
Remove MCPC-Plus support from Bukkit version - add notice to use Forge
This commit is contained in:
parent
2d95548d25
commit
7e07bff71f
@ -22,12 +22,18 @@ public abstract class BukkitVersionHelper {
|
|||||||
public static final BukkitVersionHelper getHelper() {
|
public static final BukkitVersionHelper getHelper() {
|
||||||
if(helper == null) {
|
if(helper == null) {
|
||||||
if(Bukkit.getServer().getVersion().contains("MCPC")) {
|
if(Bukkit.getServer().getVersion().contains("MCPC")) {
|
||||||
Log.info("Loader version helper for MCPC");
|
Log.severe("*********************************************************************************");
|
||||||
helper = new BukkitVersionHelperMCPC();
|
Log.severe("* MCPC-Plus is no longer supported via the Bukkit version of Dynmap. *");
|
||||||
|
Log.severe("* Install the appropriate Forge version of Dynmap. *");
|
||||||
|
Log.severe("* Add the DynmapCBBridge plugin to enable support for Dynmap-compatible plugins *");
|
||||||
|
Log.severe("*********************************************************************************");
|
||||||
}
|
}
|
||||||
else if(Bukkit.getServer().getVersion().contains("BukkitForge")) {
|
else if(Bukkit.getServer().getVersion().contains("BukkitForge")) {
|
||||||
Log.info("Loader version helper for BukkitForge");
|
Log.severe("*********************************************************************************");
|
||||||
helper = new BukkitVersionHelperBukkitForge();
|
Log.severe("* BukkitForge is not supported via the Bukkit version of Dynmap. *");
|
||||||
|
Log.severe("* Install the appropriate Forge version of Dynmap. *");
|
||||||
|
Log.severe("* Add the DynmapCBBridge plugin to enable support for Dynmap-compatible plugins *");
|
||||||
|
Log.severe("*********************************************************************************");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
helper = new BukkitVersionHelperCB();
|
helper = new BukkitVersionHelperCB();
|
||||||
|
@ -1,102 +0,0 @@
|
|||||||
package org.dynmap.bukkit;
|
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.Chunk;
|
|
||||||
import org.bukkit.ChunkSnapshot;
|
|
||||||
import org.bukkit.Server;
|
|
||||||
import org.bukkit.World;
|
|
||||||
import org.dynmap.Log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper for isolation of bukkit version specific issues
|
|
||||||
*/
|
|
||||||
public class BukkitVersionHelperBukkitForge extends BukkitVersionHelperGeneric {
|
|
||||||
BukkitVersionHelperBukkitForge() {
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
protected String getNMSPackage() {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
protected void loadNMS() {
|
|
||||||
/* biomebase */
|
|
||||||
biomebase = getNMSClass("yy");
|
|
||||||
biomebasearray = getNMSClass("[Lyy;");
|
|
||||||
/* world */
|
|
||||||
nmsworld = getNMSClass("in");
|
|
||||||
/* chunk */
|
|
||||||
chunkprovserver = getNMSClass("im");
|
|
||||||
nmschunk = getNMSClass("zz");
|
|
||||||
/* nbt */
|
|
||||||
nbttagcompound = getNMSClass("bq");
|
|
||||||
nbttagbyte = getNMSClass("bp");
|
|
||||||
nbttagshort = getNMSClass("cb");
|
|
||||||
nbttagint = getNMSClass("bx");
|
|
||||||
nbttaglong = getNMSClass("bz");
|
|
||||||
nbttagfloat = getNMSClass("bv");
|
|
||||||
nbttagdouble = getNMSClass("bt");
|
|
||||||
nbttagbytearray = getNMSClass("bo");
|
|
||||||
nbttagstring = getNMSClass("cc");
|
|
||||||
nbttagintarray = getNMSClass("bw");
|
|
||||||
/* tileentity */
|
|
||||||
nms_tileentity = getNMSClass("any");
|
|
||||||
|
|
||||||
/** Set up NMS fields **/
|
|
||||||
/* biomebase */
|
|
||||||
biomebaselist = getField(biomebase, new String[] { "a" }, biomebasearray);
|
|
||||||
biomebasetemp = getField(biomebase, new String[] { "F" }, float.class);
|
|
||||||
biomebasehumi = getField(biomebase, new String[] { "G" }, float.class);
|
|
||||||
biomebaseidstring = getField(biomebase, new String[] { "y" }, String.class);
|
|
||||||
biomebaseid = getField(biomebase, new String[] { "N" }, int.class);
|
|
||||||
/* chunk */
|
|
||||||
nmsw_chunkproviderserver = getField(nmsworld, new String[] { "b" }, chunkprovserver);
|
|
||||||
cps_unloadqueue = getFieldNoFail(chunkprovserver, new String[] { "b" }, longhashset);
|
|
||||||
if(cps_unloadqueue == null) {
|
|
||||||
Log.info("Unload queue not found - default to unload all chunks");
|
|
||||||
}
|
|
||||||
nmsc_removeentities = getMethod(nmschunk, new String[] { "d" }, new Class[0]);
|
|
||||||
nmsc_tileentities = getField(nmschunk, new String[] { "i" }, Map.class);
|
|
||||||
/* nbt */
|
|
||||||
compound_get = getMethod(nbttagcompound, new String[] { "a" }, new Class[] { String.class });
|
|
||||||
nbttagbyte_val = getField(nbttagbyte, new String[] { "a" }, byte.class);
|
|
||||||
nbttagshort_val = getField(nbttagshort, new String[] { "a" }, short.class);
|
|
||||||
nbttagint_val = getField(nbttagint, new String[] { "a" }, int.class);
|
|
||||||
nbttaglong_val = getField(nbttaglong, new String[] { "a" }, long.class);
|
|
||||||
nbttagfloat_val = getField(nbttagfloat, new String[] { "a" }, float.class);
|
|
||||||
nbttagdouble_val = getField(nbttagdouble, new String[] { "a" }, double.class);
|
|
||||||
nbttagbytearray_val = getField(nbttagbytearray, new String[] { "a" }, byte[].class);
|
|
||||||
nbttagstring_val = getField(nbttagstring, new String[] { "a" }, String.class);
|
|
||||||
nbttagintarray_val = getField(nbttagintarray, new String[] { "a" }, int[].class);
|
|
||||||
/* tileentity */
|
|
||||||
nmst_readnbt = getMethod(nms_tileentity, new String[] { "b" }, new Class[] { nbttagcompound });
|
|
||||||
nmst_x = getField(nms_tileentity, new String[] { "l" }, int.class);
|
|
||||||
nmst_y = getField(nms_tileentity, new String[] { "m" }, int.class);
|
|
||||||
nmst_z = getField(nms_tileentity, new String[] { "n" }, int.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static long chunkXZ2Int(int par0, int par1)
|
|
||||||
{
|
|
||||||
return (long)par0 & 4294967295L | ((long)par1 & 4294967295L) << 32;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* For testing unload queue for presence of givne chunk */
|
|
||||||
@Override
|
|
||||||
public boolean isInUnloadQueue(Object unloadqueue, int x, int z) {
|
|
||||||
if(unloadqueue != null) {
|
|
||||||
Set uq = (Set)unloadqueue;
|
|
||||||
return uq.contains(Long.valueOf(chunkXZ2Int(x, z)));
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void unloadChunkNoSave(World w, Chunk c, int cx, int cz) {
|
|
||||||
w.unloadChunkRequest(cx, cz);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,116 +0,0 @@
|
|||||||
package org.dynmap.bukkit;
|
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Map;
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.Chunk;
|
|
||||||
import org.bukkit.ChunkSnapshot;
|
|
||||||
import org.bukkit.Server;
|
|
||||||
import org.bukkit.World;
|
|
||||||
import org.dynmap.Log;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper for isolation of bukkit version specific issues
|
|
||||||
*/
|
|
||||||
public class BukkitVersionHelperMCPC extends BukkitVersionHelperGeneric {
|
|
||||||
private Method cps_unload100;
|
|
||||||
private int cnt;
|
|
||||||
|
|
||||||
BukkitVersionHelperMCPC() {
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
protected String getNMSPackage() {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
protected void loadNMS() {
|
|
||||||
/* biomebase */
|
|
||||||
biomebase = getNMSClass("yy");
|
|
||||||
biomebasearray = getNMSClass("[Lyy;");
|
|
||||||
/* world */
|
|
||||||
nmsworld = getNMSClass("in");
|
|
||||||
/* chunk */
|
|
||||||
chunkprovserver = getNMSClass("im");
|
|
||||||
nmschunk = getNMSClass("zz");
|
|
||||||
/* nbt */
|
|
||||||
nbttagcompound = getNMSClass("bq");
|
|
||||||
nbttagbyte = getNMSClass("bp");
|
|
||||||
nbttagshort = getNMSClass("cb");
|
|
||||||
nbttagint = getNMSClass("bx");
|
|
||||||
nbttaglong = getNMSClass("bz");
|
|
||||||
nbttagfloat = getNMSClass("bv");
|
|
||||||
nbttagdouble = getNMSClass("bt");
|
|
||||||
nbttagbytearray = getNMSClass("bo");
|
|
||||||
nbttagstring = getNMSClass("cc");
|
|
||||||
nbttagintarray = getNMSClass("bw");
|
|
||||||
/* tileentity */
|
|
||||||
nms_tileentity = getNMSClass("any");
|
|
||||||
|
|
||||||
/* Get unload queue classes */
|
|
||||||
longhashset = getOBCClassNoFail("org.bukkit.craftbukkit.util.LongHashSet");
|
|
||||||
if(longhashset != null) {
|
|
||||||
lhs_containskey = getMethod(longhashset, new String[] { "contains" }, new Class[] { int.class, int.class });
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
longhashset = getOBCClass("org.bukkit.craftbukkit.util.LongHashset");
|
|
||||||
lhs_containskey = getMethod(longhashset, new String[] { "containsKey" }, new Class[] { int.class, int.class });
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Set up NMS fields **/
|
|
||||||
/* biomebase */
|
|
||||||
biomebaselist = getField(biomebase, new String[] { "a" }, biomebasearray);
|
|
||||||
biomebasetemp = getField(biomebase, new String[] { "F" }, float.class);
|
|
||||||
biomebasehumi = getField(biomebase, new String[] { "G" }, float.class);
|
|
||||||
biomebaseidstring = getField(biomebase, new String[] { "y" }, String.class);
|
|
||||||
biomebaseid = getField(biomebase, new String[] { "N" }, int.class);
|
|
||||||
/* chunk */
|
|
||||||
nmsw_chunkproviderserver = getField(nmsworld, new String[] { "b" }, chunkprovserver);
|
|
||||||
cps_unloadqueue = getFieldNoFail(chunkprovserver, new String[] { "b" }, longhashset);
|
|
||||||
if(cps_unloadqueue == null) {
|
|
||||||
Log.info("Unload queue not found - default to unload all chunks");
|
|
||||||
}
|
|
||||||
cps_unload100 = getMethod(chunkprovserver, new String[] { "b" }, new Class[0]);
|
|
||||||
|
|
||||||
nmsc_removeentities = getMethod(nmschunk, new String[] { "d" }, new Class[0]);
|
|
||||||
nmsc_tileentities = getField(nmschunk, new String[] { "i" }, Map.class);
|
|
||||||
/* nbt */
|
|
||||||
compound_get = getMethod(nbttagcompound, new String[] { "a" }, new Class[] { String.class });
|
|
||||||
nbttagbyte_val = getField(nbttagbyte, new String[] { "a" }, byte.class);
|
|
||||||
nbttagshort_val = getField(nbttagshort, new String[] { "a" }, short.class);
|
|
||||||
nbttagint_val = getField(nbttagint, new String[] { "a" }, int.class);
|
|
||||||
nbttaglong_val = getField(nbttaglong, new String[] { "a" }, long.class);
|
|
||||||
nbttagfloat_val = getField(nbttagfloat, new String[] { "a" }, float.class);
|
|
||||||
nbttagdouble_val = getField(nbttagdouble, new String[] { "a" }, double.class);
|
|
||||||
nbttagbytearray_val = getField(nbttagbytearray, new String[] { "a" }, byte[].class);
|
|
||||||
nbttagstring_val = getField(nbttagstring, new String[] { "a" }, String.class);
|
|
||||||
nbttagintarray_val = getField(nbttagintarray, new String[] { "a" }, int[].class);
|
|
||||||
/* tileentity */
|
|
||||||
nmst_readnbt = getMethod(nms_tileentity, new String[] { "b" }, new Class[] { nbttagcompound });
|
|
||||||
nmst_x = getField(nms_tileentity, new String[] { "l" }, int.class);
|
|
||||||
nmst_y = getField(nms_tileentity, new String[] { "m" }, int.class);
|
|
||||||
nmst_z = getField(nms_tileentity, new String[] { "n" }, int.class);
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void unloadChunkNoSave(World w, Chunk c, int cx, int cz) {
|
|
||||||
w.unloadChunkRequest(cx, cz);
|
|
||||||
cnt++;
|
|
||||||
if(cnt > 20) {
|
|
||||||
cnt = 0;
|
|
||||||
Object nmsw = this.getNMSWorld(w);
|
|
||||||
if((nmsw != null) && (cps_unload100 != null)) {
|
|
||||||
Object cps = getFieldValue(nmsw, nmsw_chunkproviderserver, null); // Get chunkproviderserver
|
|
||||||
if(cps != null) {
|
|
||||||
try {
|
|
||||||
this.cps_unload100.invoke(cps, new Object[0]);
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
} catch (IllegalAccessException e) {
|
|
||||||
} catch (InvocationTargetException e) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -114,7 +114,7 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
private World last_world;
|
private World last_world;
|
||||||
private BukkitWorld last_bworld;
|
private BukkitWorld last_bworld;
|
||||||
|
|
||||||
private BukkitVersionHelper helper = BukkitVersionHelper.getHelper();
|
private BukkitVersionHelper helper;
|
||||||
|
|
||||||
private final BukkitWorld getWorldByName(String name) {
|
private final BukkitWorld getWorldByName(String name) {
|
||||||
if((last_world != null) && (last_world.getName().equals(name))) {
|
if((last_world != null) && (last_world.getName().equals(name))) {
|
||||||
@ -686,9 +686,19 @@ public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onLoad() {
|
||||||
pm = this.getServer().getPluginManager();
|
Log.setLogger(this.getLogger(), "");
|
||||||
|
|
||||||
|
helper = BukkitVersionHelper.getHelper();
|
||||||
|
pm = this.getServer().getPluginManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
if (helper == null) {
|
||||||
|
Log.info("Dynmap is disabled (unsupported platform)");
|
||||||
|
return;
|
||||||
|
}
|
||||||
PluginDescriptionFile pdfFile = this.getDescription();
|
PluginDescriptionFile pdfFile = this.getDescription();
|
||||||
version = pdfFile.getVersion();
|
version = pdfFile.getVersion();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user