It works! Fixed all found errors

This commit is contained in:
Norbi Peti 2020-09-09 17:48:37 +02:00
parent c245d48033
commit 82cefec71a
No known key found for this signature in database
GPG key ID: DBA4C4549A927E56
2 changed files with 83 additions and 43 deletions

View file

@ -16,16 +16,6 @@ import java.io.File;
import java.util.*; import java.util.*;
public class CustomDimensions extends JavaPlugin implements Listener { public class CustomDimensions extends JavaPlugin implements Listener {
/*@Command2.Subcommand
public void def(CommandSender sender, String name) {
*sender.sendMessage("Starting creation of " + name + "...");
var world = load();
if (world == null)
sender.sendMessage("Failed to load world.");
else
sender.sendMessage("World loaded! " + world.getName());*
}*/
@Override @Override
public void onEnable() { public void onEnable() {
//Bukkit.getPluginManager().registerEvents(this, this); //Bukkit.getPluginManager().registerEvents(this, this);
@ -39,34 +29,41 @@ public class CustomDimensions extends JavaPlugin implements Listener {
} }
public void load() throws Exception { public void load() throws Exception {
System.out.println("Loading..."); getLogger().info("Loading...");
var console = ((CraftServer) Bukkit.getServer()).getServer(); var console = ((CraftServer) Bukkit.getServer()).getServer();
var field = console.getClass().getSuperclass().getDeclaredField("saveData"); var field = console.getClass().getSuperclass().getDeclaredField("saveData");
field.setAccessible(true); field.setAccessible(true);
var saveData = (SaveData) field.get(console); var saveData = (SaveData) field.get(console);
//IWorldDataServer iworlddataserver = saveData.H(); GeneratorSettings mainGenSettings = saveData.getGeneratorSettings();
GeneratorSettings generatorsettings = saveData.getGeneratorSettings(); RegistryMaterials<WorldDimension> dimensionRegistry = mainGenSettings.d();
RegistryMaterials<WorldDimension> registrymaterials = generatorsettings.d();
var worldloadlistener = console.worldLoadListenerFactory.create(11);
var iterator = registrymaterials.d().iterator(); var dimIterator = dimensionRegistry.d().iterator();
var mainWorld = Bukkit.getWorlds().get(0); var mainWorld = Bukkit.getWorlds().get(0);
var convertable = Convertable.a(Bukkit.getWorldContainer().toPath()); var convertable = Convertable.a(Bukkit.getWorldContainer().toPath());
while (iterator.hasNext()) { while (dimIterator.hasNext()) {
Map.Entry<ResourceKey<WorldDimension>, WorldDimension> entry = iterator.next(); Map.Entry<ResourceKey<WorldDimension>, WorldDimension> dimEntry = dimIterator.next();
ResourceKey<WorldDimension> resourcekey = entry.getKey(); ResourceKey<WorldDimension> dimKey = dimEntry.getKey();
if (resourcekey != WorldDimension.OVERWORLD if (dimKey != WorldDimension.OVERWORLD
&& resourcekey != WorldDimension.THE_NETHER && dimKey != WorldDimension.THE_NETHER
&& resourcekey != WorldDimension.THE_END) { && dimKey != WorldDimension.THE_END) {
ResourceKey<World> resourcekey1 = ResourceKey.a(IRegistry.L, resourcekey.a()); System.out.println("First check");
DimensionManager dimensionmanager = entry.getValue().b(); for (var dimMan : console.f.a()) {
ChunkGenerator chunkgenerator = entry.getValue().c(); //TODO: Shade try {
var name = resourcekey.a().getKey(); System.out.println("Found dim man for key: " + console.f.a().getKey(dimMan));
var session = convertable.new ConversionSession(name, resourcekey) { //The original session isn't prepared for custom dimensions System.out.println("Resource key: " + console.f.a().c(dimMan));
} catch (Exception e) {
e.printStackTrace();
}
}
ResourceKey<World> worldKey = ResourceKey.a(IRegistry.L, dimKey.a());
DimensionManager dimensionmanager = dimEntry.getValue().b();
ChunkGenerator chunkgenerator = dimEntry.getValue().c(); //TODO: Shade
var name = dimKey.a().getKey();
var session = convertable.new ConversionSession(name, dimKey) { //The original session isn't prepared for custom dimensions
@Override @Override
public File a(ResourceKey<World> resourcekey) { public File a(ResourceKey<World> resourcekey) {
return new File(this.folder.toFile(), "custom"); return new File(this.folder.toFile(), "custom");
@ -74,7 +71,7 @@ public class CustomDimensions extends JavaPlugin implements Listener {
}; };
MinecraftServer.convertWorld(session); MinecraftServer.convertWorld(session);
//Load world settings and create a custom //Load world settings or create default values
RegistryReadOps<NBTBase> registryreadops = RegistryReadOps.a(DynamicOpsNBT.a, console.dataPackResources.h(), console.f); RegistryReadOps<NBTBase> registryreadops = RegistryReadOps.a(DynamicOpsNBT.a, console.dataPackResources.h(), console.f);
WorldDataServer worlddata = (WorldDataServer) session.a(registryreadops, console.datapackconfiguration); WorldDataServer worlddata = (WorldDataServer) session.a(registryreadops, console.datapackconfiguration);
if (worlddata == null) { if (worlddata == null) {
@ -82,15 +79,16 @@ public class CustomDimensions extends JavaPlugin implements Listener {
properties.put("level-seed", Objects.toString(mainWorld.getSeed())); properties.put("level-seed", Objects.toString(mainWorld.getSeed()));
properties.put("generate-structures", Objects.toString(true)); properties.put("generate-structures", Objects.toString(true));
properties.put("level-type", WorldType.NORMAL.getName()); properties.put("level-type", WorldType.NORMAL.getName());
GeneratorSettings generatorsettings2 = GeneratorSettings.a(console.aX(), properties); GeneratorSettings dimGenSettings = GeneratorSettings.a(console.aX(), properties);
WorldSettings worldSettings = new WorldSettings(name, WorldSettings worldSettings = new WorldSettings(name,
EnumGamemode.getById(Bukkit.getDefaultGameMode().getValue()), EnumGamemode.getById(Bukkit.getDefaultGameMode().getValue()),
false, //Hardcore false, //Hardcore
EnumDifficulty.EASY, false, new GameRules(), console.datapackconfiguration); EnumDifficulty.EASY, false, new GameRules(), console.datapackconfiguration);
worlddata = new WorldDataServer(worldSettings, generatorsettings2, Lifecycle.stable()); worlddata = new WorldDataServer(worldSettings, dimGenSettings, Lifecycle.stable());
} }
var data = DimensionWorldData.create(worlddata, name, EnumGamemode.CREATIVE); //Create a custom WorldDataServer that is aware that it's a dimension and delegates most calls to the main world
var data = DimensionWorldData.create(worlddata, name);
worlddata.checkName(name); worlddata.checkName(name);
worlddata.a(console.getServerModName(), console.getModded().isPresent()); worlddata.a(console.getServerModName(), console.getModded().isPresent());
@ -102,22 +100,62 @@ public class CustomDimensions extends JavaPlugin implements Listener {
.collect(ImmutableSet.toImmutableSet())); .collect(ImmutableSet.toImmutableSet()));
} }
List<MobSpawner> list = ImmutableList.of(new MobSpawnerPhantom(), new MobSpawnerPatrol(), new MobSpawnerCat(), new VillageSiege(), new MobSpawnerTrader(worlddata)); List<MobSpawner> spawners = ImmutableList.of(new MobSpawnerPhantom(), new MobSpawnerPatrol(), new MobSpawnerCat(), new VillageSiege(), new MobSpawnerTrader(worlddata));
//in bf but not in bi
System.out.println("Second check");
ResourceKey<DimensionManager> dimManKey = null;
int lastID = -1;
for (var dimMan : console.f.a()) {
try {
System.out.println("Found dim man for key: " + console.f.a().getKey(dimMan));
var key = console.f.a().c(dimMan);
System.out.println("Resource key: " + key);
int id = console.f.a().a(dimensionmanager);
System.out.println("ID: " + id);
if (id > lastID) lastID = id;
if (key.isPresent() && key.get().a().getKey().equals(name)) {
//Register dimension manager in registry //Register dimension manager in registry
ResourceKey<DimensionManager> dimManResKey = ResourceKey.a(IRegistry.K, resourcekey.a()); //var originalManagerID = console.f.a().a(dimensionmanager); - -1
((RegistryMaterials<DimensionManager>) console.f.a()).a(dimManResKey, dimensionmanager, Lifecycle.stable()); //System.out.println("Replacing dimension manager with ID " + originalManagerID);
dimManKey = key.get();
}
} catch (Exception e) {
e.printStackTrace();
}
}
if (dimManKey != null) {
ResourceKey<DimensionManager> dimManResKey = ResourceKey.a(IRegistry.K, dimKey.a());
System.out.println("Replacing with " + dimManResKey);
((RegistryMaterials<DimensionManager>) console.f.a()).a(OptionalInt.empty(), dimManKey, dimensionmanager, Lifecycle.stable());
}
//in bf but not in bi
System.out.println("Third check");
for (var dimMan : console.f.a()) {
try {
System.out.println("Found dim man for key: " + console.f.a().getKey(dimMan));
System.out.println("Resource key: " + console.f.a().c(dimMan));
} catch (Exception e) {
e.printStackTrace();
}
}
var worldloadlistener = console.worldLoadListenerFactory.create(11);
//RegistryMaterials<WorldDimension> registrymaterials = worlddata.getGeneratorSettings().d(); //RegistryMaterials<WorldDimension> registrymaterials = worlddata.getGeneratorSettings().d();
//WorldDimension worlddimension = (WorldDimension) registrymaterials2.a(actualDimension); //WorldDimension worlddimension = (WorldDimension) registrymaterials2.a(actualDimension);
//Use the main world's dimension data //Use the main world's dimension data
WorldServer worldserver = new WorldServer(console, console.executorService, session, WorldServer worldserver = new WorldServer(console, console.executorService, session,
data, resourcekey1, dimensionmanager, worldloadlistener, chunkgenerator, data, worldKey, dimensionmanager, worldloadlistener, chunkgenerator,
false, //isDebugWorld false, //isDebugWorld
BiomeManager.a(mainWorld.getSeed()), //Biome seed BiomeManager.a(mainWorld.getSeed()), //Biome seed
list, false, org.bukkit.World.Environment.NORMAL, null); spawners, false, org.bukkit.World.Environment.NORMAL, null);
data.world = worldserver; //Mocked world data
worlddata.world = worldserver; //Inner world data
//((CraftWorld) mainWorld).getHandle().getWorldBorder().a(new IWorldBorderListener.a(worldserver.getWorldBorder())); //((CraftWorld) mainWorld).getHandle().getWorldBorder().a(new IWorldBorderListener.a(worldserver.getWorldBorder()));
@ -133,7 +171,7 @@ public class CustomDimensions extends JavaPlugin implements Listener {
} }
} }
} }
System.out.println("Loading finished!"); getLogger().info("Loading finished!");
} }
/*private WorldServer createWorldServer(WorldDataMutable worldData, String name) throws Exception { /*private WorldServer createWorldServer(WorldDataMutable worldData, String name) throws Exception {

View file

@ -1,7 +1,9 @@
package buttondevteam.customdimensions; package buttondevteam.customdimensions;
import com.mojang.serialization.Lifecycle; import com.mojang.serialization.Lifecycle;
import net.minecraft.server.v1_16_R2.*; import net.minecraft.server.v1_16_R2.GeneratorSettings;
import net.minecraft.server.v1_16_R2.WorldDataServer;
import net.minecraft.server.v1_16_R2.WorldSettings;
import org.mockito.Mockito; import org.mockito.Mockito;
public class DimensionWorldData extends WorldDataServer { public class DimensionWorldData extends WorldDataServer {
@ -9,13 +11,13 @@ public class DimensionWorldData extends WorldDataServer {
super(worldsettings, generatorsettings, lifecycle); super(worldsettings, generatorsettings, lifecycle);
} }
public static DimensionWorldData create(WorldDataServer data, String name, EnumGamemode gamemode) { public static DimensionWorldData create(WorldDataServer data, String name) {
var mock = Mockito.mock(DimensionWorldData.class, invocation -> { var mock = Mockito.mock(DimensionWorldData.class, Mockito.withSettings().defaultAnswer(invocation -> {
if (invocation.getMethod().getDeclaringClass() == DimensionWorldData.class) if (invocation.getMethod().getDeclaringClass() == DimensionWorldData.class)
return invocation.callRealMethod(); return invocation.callRealMethod();
return invocation.getMethod().invoke(data, invocation.getArguments()); return invocation.getMethod().invoke(data, invocation.getArguments());
}); }).stubOnly());
mock.b = new WorldSettings(name, gamemode, false, EnumDifficulty.EASY, true, data.q(), data.D()); mock.b = new WorldSettings(name, data.getGameType(), false, data.getDifficulty(), true, data.q(), data.D());
return mock; return mock;
} }
} }