diff --git a/patches/minecraft/net/minecraft/client/Minecraft.edit.java b/patches/minecraft/net/minecraft/client/Minecraft.edit.java index b3360a0..3c1d03c 100644 --- a/patches/minecraft/net/minecraft/client/Minecraft.edit.java +++ b/patches/minecraft/net/minecraft/client/Minecraft.edit.java @@ -22,7 +22,7 @@ > DELETE 1 @ 1 : 4 -> CHANGE 1 : 60 @ 1 : 4 +> CHANGE 1 : 61 @ 1 : 4 ~ ~ import net.eaglerforge.EaglerForge; @@ -38,6 +38,7 @@ ~ ~ import net.lax1dude.eaglercraft.v1_8.Display; ~ import net.lax1dude.eaglercraft.v1_8.EagRuntime; +~ import net.lax1dude.eaglercraft.v1_8.EagUtils; ~ import net.lax1dude.eaglercraft.v1_8.EaglerXBungeeVersion; ~ import net.lax1dude.eaglercraft.v1_8.HString; ~ import net.lax1dude.eaglercraft.v1_8.IOUtils; @@ -450,7 +451,21 @@ ~ Util.func_181617_a((FutureTask) this.scheduledTasks.remove(0), logger); -> DELETE 18 @ 18 : 26 +> CHANGE 7 : 18 @ 7 : 8 + +~ if (this.timer.elapsedTicks > 1) { +~ long watchdog = System.currentTimeMillis(); +~ for (int j = 0; j < this.timer.elapsedTicks; ++j) { +~ this.runTick(); +~ long millis = System.currentTimeMillis(); +~ if (millis - watchdog > 50l) { +~ watchdog = millis; +~ EagUtils.sleep(0l); +~ } +~ } +~ } else if (this.timer.elapsedTicks == 1) { + +> DELETE 10 @ 10 : 18 > CHANGE 1 : 4 @ 1 : 5 @@ -523,9 +538,13 @@ + Mouse.tickCursorShape(); -> INSERT 5 : 6 @ 5 +> INSERT 5 : 10 @ 5 -+ Display.setVSync(this.gameSettings.enableVsync); ++ if (Display.isVSyncSupported()) { ++ Display.setVSync(this.gameSettings.enableVsync); ++ } else { ++ this.gameSettings.enableVsync = false; ++ } > DELETE 34 @ 34 : 52 @@ -788,7 +807,11 @@ ~ GameSettings g = theMinecraft.gameSettings; ~ return g.ambientOcclusion != 0 && !g.shadersAODisable; -> CHANGE 130 : 131 @ 130 : 131 +> CHANGE 2 : 3 @ 2 : 3 + +~ public void middleClickMouse() { + +> CHANGE 127 : 128 @ 127 : 128 ~ return EagRuntime.getVersion(); diff --git a/patches/minecraft/net/minecraft/client/audio/SoundHandler.edit.java b/patches/minecraft/net/minecraft/client/audio/SoundHandler.edit.java index 0ec2942..eca9fb6 100644 --- a/patches/minecraft/net/minecraft/client/audio/SoundHandler.edit.java +++ b/patches/minecraft/net/minecraft/client/audio/SoundHandler.edit.java @@ -30,7 +30,9 @@ > DELETE 7 @ 7 : 11 -> DELETE 3 @ 3 : 18 +> CHANGE 3 : 4 @ 3 : 18 + +~ private static final Logger tipLogger = LogManager.getLogger("EaglercraftX"); > CHANGE 3 : 4 @ 3 : 4 @@ -44,7 +46,14 @@ ~ for (Entry entry : (Set) map.entrySet()) { -> INSERT 14 : 24 @ 14 +> INSERT 12 : 16 @ 12 + ++ if (this.sndRegistry.getObject(new ResourceLocation("minecraft:sounds/music/game/calm1.ogg")) == null) { ++ tipLogger.info( ++ "Download this resource pack if you want music: https://bafybeiayojww5jfyzvlmtuk7l5ufkt7nlfto7mhwmzf2vs4bvsjd5ouiuq.ipfs.nftstorage.link/?filename=Music_For_Eaglercraft.zip"); ++ } + +> INSERT 2 : 12 @ 2 + public static class SoundMap { + diff --git a/patches/minecraft/net/minecraft/client/gui/GuiMainMenu.edit.java b/patches/minecraft/net/minecraft/client/gui/GuiMainMenu.edit.java index 9acb53d..57d89cc 100644 --- a/patches/minecraft/net/minecraft/client/gui/GuiMainMenu.edit.java +++ b/patches/minecraft/net/minecraft/client/gui/GuiMainMenu.edit.java @@ -329,7 +329,7 @@ > CHANGE 1 : 3 @ 1 : 2 ~ this.drawString(this.fontRendererObj, s, 2, this.height - 20, -1); -~ s = EaglercraftVersion.mainMenuStringB; +~ s = EaglercraftVersion.getMainMenuStringB(); > CHANGE 1 : 3 @ 1 : 2 diff --git a/patches/minecraft/net/minecraft/client/renderer/entity/RenderManager.edit.java b/patches/minecraft/net/minecraft/client/renderer/entity/RenderManager.edit.java index 1dfb3d3..c59f9a2 100644 --- a/patches/minecraft/net/minecraft/client/renderer/entity/RenderManager.edit.java +++ b/patches/minecraft/net/minecraft/client/renderer/entity/RenderManager.edit.java @@ -7,11 +7,12 @@ > DELETE 2 @ 2 : 3 -> INSERT 1 : 9 @ 1 +> INSERT 1 : 10 @ 1 + + import com.google.common.collect.Maps; + ++ import net.lax1dude.eaglercraft.v1_8.EagRuntime; + import net.lax1dude.eaglercraft.v1_8.opengl.GlStateManager; + import net.lax1dude.eaglercraft.v1_8.opengl.OpenGlHelper; + import net.lax1dude.eaglercraft.v1_8.opengl.WorldRenderer; @@ -32,12 +33,16 @@ + private RenderPlayer eaglerRenderer; -> CHANGE 82 : 88 @ 82 : 83 +> CHANGE 82 : 92 @ 82 : 83 ~ this.skinMap.put("slim", new RenderPlayer(this, true, false)); ~ this.skinMap.put("zombie", new RenderPlayer(this, false, true)); -~ this.eaglerRenderer = new RenderHighPoly(this, this.playerRenderer.getMainModel(), -~ this.playerRenderer.shadowSize); +~ if (EagRuntime.getConfiguration().isAllowFNAWSkins()) { +~ this.eaglerRenderer = new RenderHighPoly(this, this.playerRenderer.getMainModel(), +~ this.playerRenderer.shadowSize); +~ } else { +~ this.eaglerRenderer = this.playerRenderer; +~ } ~ this.skinMap.put("eagler", ~ Minecraft.getMinecraft().gameSettings.enableFNAWSkins ? this.eaglerRenderer : this.playerRenderer); diff --git a/patches/minecraft/net/minecraft/entity/ai/EntityAIBase.edit.java b/patches/minecraft/net/minecraft/entity/ai/EntityAIBase.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/ai/EntityAIBase.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/ai/EntityJumpHelper.edit.java b/patches/minecraft/net/minecraft/entity/ai/EntityJumpHelper.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/ai/EntityJumpHelper.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/ai/EntityLookHelper.edit.java b/patches/minecraft/net/minecraft/entity/ai/EntityLookHelper.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/ai/EntityLookHelper.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/ai/EntityMoveHelper.edit.java b/patches/minecraft/net/minecraft/entity/ai/EntityMoveHelper.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/ai/EntityMoveHelper.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/ai/EntitySenses.edit.java b/patches/minecraft/net/minecraft/entity/ai/EntitySenses.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/ai/EntitySenses.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/item/EntityEnderCrystal.edit.java b/patches/minecraft/net/minecraft/entity/item/EntityEnderCrystal.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/item/EntityEnderCrystal.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/item/EntityEnderPearl.edit.java b/patches/minecraft/net/minecraft/entity/item/EntityEnderPearl.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/item/EntityEnderPearl.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/entity/item/EntityFireworkRocket.edit.java b/patches/minecraft/net/minecraft/entity/item/EntityFireworkRocket.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/entity/item/EntityFireworkRocket.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/pathfinding/PathPoint.edit.java b/patches/minecraft/net/minecraft/pathfinding/PathPoint.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/pathfinding/PathPoint.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/server/management/ItemInWorldManager.edit.java b/patches/minecraft/net/minecraft/server/management/ItemInWorldManager.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/server/management/ItemInWorldManager.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/server/management/ServerConfigurationManager.edit.java b/patches/minecraft/net/minecraft/server/management/ServerConfigurationManager.edit.java index 99168d7..412e71c 100644 --- a/patches/minecraft/net/minecraft/server/management/ServerConfigurationManager.edit.java +++ b/patches/minecraft/net/minecraft/server/management/ServerConfigurationManager.edit.java @@ -53,9 +53,11 @@ > DELETE 1 @ 1 : 5 -> DELETE 2 @ 2 : 4 +> CHANGE 2 : 3 @ 2 : 5 -> CHANGE 3 : 5 @ 3 : 9 +~ this.maxPlayers = 100; + +> CHANGE 2 : 4 @ 2 : 8 ~ public void initializeConnectionToPlayer(IntegratedServerPlayerNetworkManager netManager, EntityPlayerMP playerIn) { ~ GameProfile gameprofile1 = playerIn.getGameProfile(); @@ -131,14 +133,12 @@ + } + -> CHANGE 4 : 11 @ 4 : 11 +> CHANGE 4 : 9 @ 4 : 11 ~ public String allowUserToConnect(GameProfile gameprofile) { -~ return this.playerEntityList.size() >= this.maxPlayers && !this.func_183023_f(gameprofile) -~ ? "The server is full!" -~ : (doesPlayerAlreadyExist(gameprofile) -~ ? "\"" + gameprofile.getName() + "\" is already playing on this world!" -~ : null); +~ return doesPlayerAlreadyExist(gameprofile) +~ ? "\"" + gameprofile.getName() + "\" is already playing on this world!" +~ : null; ~ } > CHANGE 1 : 7 @ 1 : 9 @@ -225,7 +225,7 @@ ~ worldIn.theItemInWorldManager.initializeGameType(parWorld.getWorldInfo().getGameType()); ~ } else { -~ parEntityPlayerMP2.theItemInWorldManager.setGameType(lanGamemode); +~ worldIn.theItemInWorldManager.setGameType(lanGamemode); ~ } > CHANGE 7 : 8 @ 7 : 8 diff --git a/patches/minecraft/net/minecraft/village/VillageDoorInfo.edit.java b/patches/minecraft/net/minecraft/village/VillageDoorInfo.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/village/VillageDoorInfo.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/WorldType.edit.java b/patches/minecraft/net/minecraft/world/WorldType.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/WorldType.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/demo/DemoWorldManager.edit.java b/patches/minecraft/net/minecraft/world/demo/DemoWorldManager.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/demo/DemoWorldManager.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/gen/ChunkProviderDebug.edit.java b/patches/minecraft/net/minecraft/world/gen/ChunkProviderDebug.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/gen/ChunkProviderDebug.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/gen/layer/IntCache.edit.java b/patches/minecraft/net/minecraft/world/gen/layer/IntCache.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/gen/layer/IntCache.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/gen/structure/MapGenStructureData.edit.java b/patches/minecraft/net/minecraft/world/gen/structure/MapGenStructureData.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/gen/structure/MapGenStructureData.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/gen/structure/StructureBoundingBox.edit.java b/patches/minecraft/net/minecraft/world/gen/structure/StructureBoundingBox.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/gen/structure/StructureBoundingBox.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/patches/minecraft/net/minecraft/world/pathfinder/NodeProcessor.edit.java b/patches/minecraft/net/minecraft/world/pathfinder/NodeProcessor.edit.java new file mode 100644 index 0000000..7572609 --- /dev/null +++ b/patches/minecraft/net/minecraft/world/pathfinder/NodeProcessor.edit.java @@ -0,0 +1,8 @@ + +# Eagler Context Redacted Diff +# Copyright (c) 2024 lax1dude. All rights reserved. + +# Version: 1.0 +# Author: lax1dude + +> EOF diff --git a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformApplication.java b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformApplication.java index ceda34c..8926416 100644 --- a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformApplication.java +++ b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformApplication.java @@ -64,8 +64,12 @@ public class PlatformApplication { String str = glfwGetClipboardString(win); return str == null ? "" : str; } - + public static void setLocalStorage(String name, byte[] data) { + setLocalStorage(name, data, true); + } + + public static void setLocalStorage(String name, byte[] data, boolean hooks) { if(data == null) { (new File("_eagstorage."+name+".dat")).delete(); }else { @@ -76,8 +80,12 @@ public class PlatformApplication { } } } - + public static byte[] getLocalStorage(String data) { + return getLocalStorage(data, true); + } + + public static byte[] getLocalStorage(String data, boolean hooks) { File f = new File("_eagstorage."+data+".dat"); if(!f.isFile()) { return null; diff --git a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformInput.java b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformInput.java index d15647e..d864871 100644 --- a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformInput.java +++ b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/PlatformInput.java @@ -230,6 +230,10 @@ public class PlatformInput { glfwSwapBuffers(win); } + public static boolean isVSyncSupported() { + return true; + } + public static boolean wasResized() { boolean b = windowResized; windowResized = false; diff --git a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/lwjgl/DesktopClientConfigAdapter.java b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/lwjgl/DesktopClientConfigAdapter.java index 3ce88b5..1380861 100644 --- a/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/lwjgl/DesktopClientConfigAdapter.java +++ b/sources/lwjgl/java/net/lax1dude/eaglercraft/v1_8/internal/lwjgl/DesktopClientConfigAdapter.java @@ -8,6 +8,7 @@ import org.json.JSONObject; import net.lax1dude.eaglercraft.v1_8.EaglercraftRandom; import net.lax1dude.eaglercraft.v1_8.EaglercraftVersion; import net.lax1dude.eaglercraft.v1_8.internal.IClientConfigAdapter; +import net.lax1dude.eaglercraft.v1_8.internal.IClientConfigAdapterHooks; import net.lax1dude.eaglercraft.v1_8.sp.relay.RelayEntry; /** @@ -31,6 +32,8 @@ public class DesktopClientConfigAdapter implements IClientConfigAdapter { public final List defaultServers = new ArrayList(); + private final DesktopClientConfigAdapterHooks hooks = new DesktopClientConfigAdapterHooks(); + @Override public String getDefaultLocale() { return "en_US"; @@ -129,4 +132,32 @@ public class DesktopClientConfigAdapter implements IClientConfigAdapter { return false; } + @Override + public boolean isAllowFNAWSkins() { + return true; + } + + @Override + public String getLocalStorageNamespace() { + return EaglercraftVersion.localStorageNamespace; + } + + @Override + public IClientConfigAdapterHooks getHooks() { + return hooks; + } + + private static class DesktopClientConfigAdapterHooks implements IClientConfigAdapterHooks { + + @Override + public void callLocalStorageSavedHook(String key, String base64) { + + } + + @Override + public String callLocalStorageLoadHook(String key) { + return null; + } + + } } diff --git a/sources/main/java/net/eaglerforge/EaglerForge.java b/sources/main/java/net/eaglerforge/EaglerForge.java index 3e39465..1f630ab 100644 --- a/sources/main/java/net/eaglerforge/EaglerForge.java +++ b/sources/main/java/net/eaglerforge/EaglerForge.java @@ -4,6 +4,11 @@ import net.lax1dude.eaglercraft.v1_8.log4j.LogManager; import net.lax1dude.eaglercraft.v1_8.log4j.Logger; import net.minecraft.client.Minecraft; import org.teavm.jso.JSBody; +import org.teavm.jso.browser.Window; +import org.teavm.jso.dom.html.HTMLBodyElement; +import org.teavm.jso.dom.html.HTMLElement; +import org.teavm.jso.dom.html.HTMLImageElement; + import static net.minecraft.client.Minecraft.mojangLogo; @@ -20,19 +25,36 @@ public class EaglerForge { public static native void jsprompt(String message); @JSBody(params = { "message", "default_text" }, script = "prompt(message, default_text)") public static native void jspromptdt(String message, String default_text); - - @JSBody(script = "displayanvil()") - public static native void displayanvil(); - - @JSBody(script = "var img = document.getElementById('anvil');\n" + - "if (img) img.remove();") - public static native void removeanvil(); - - + + public static void displayanvil() { + HTMLImageElement img = (HTMLImageElement) Window.current().getDocument().createElement("img"); + img.setAttribute("id", "anvil"); + img.setSrc(src); + img.setAttribute("draggable", "false"); + img.getStyle().setProperty("position", "fixed"); + img.getStyle().setProperty("bottom", "0"); + img.getStyle().setProperty("right", "0"); + img.getStyle().setProperty("width", "200px"); + img.getStyle().setProperty("height", "auto"); + + HTMLBodyElement body = (HTMLBodyElement) Window.current().getDocument().getBody(); + body.appendChild(img); + } + + public static void removeanvil() { + HTMLElement element = Window.current().getDocument().getElementById("anvil"); + + if (element != null) { + element.getParentNode().removeChild(element); + } + } public static void init() { log.info("Starting EaglerForge!"); displayanvil(); log.info("Loading Mods..."); } -} + + public static String src = ""; + +} \ No newline at end of file diff --git a/sources/main/java/net/eaglerforge/api/BaseData.java b/sources/main/java/net/eaglerforge/api/BaseData.java index 5aa041b..0ad427b 100644 --- a/sources/main/java/net/eaglerforge/api/BaseData.java +++ b/sources/main/java/net/eaglerforge/api/BaseData.java @@ -5,6 +5,17 @@ import org.teavm.jso.JSObject; import org.teavm.jso.JSFunctor; public abstract class BaseData implements JSObject { + @JSFunctor + public interface ClassFinderCallback extends JSObject { + BaseData onCallback(String classIdentifier); + } + + @JSBody(params = { "key", "value" }, script = "this[key]=value;") + public native void setCallbackClassFinder(String key, ClassFinderCallback value); + + + + @JSFunctor public interface VoidCallback extends JSObject { void onCallback(); @@ -20,6 +31,16 @@ public abstract class BaseData implements JSObject { JSObject onCallback(); } + @JSFunctor + public interface ReflectiveObjectCallback extends JSObject { + Object onCallback(); + } + + @JSFunctor + public interface DataReflectiveObjectCallback extends JSObject { + Object onCallback(BaseData data); + } + @JSFunctor public interface FloatCallback extends JSObject { float onCallback(); @@ -138,6 +159,9 @@ public abstract class BaseData implements JSObject { @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void set(String key, String value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") + public native void set(String key, Object value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void set(String key, int value); @@ -162,6 +186,9 @@ public abstract class BaseData implements JSObject { @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void set(String key, BaseData value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") + public native void setReflective(String key, Object value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void set(String key, String[] value); @@ -216,6 +243,12 @@ public abstract class BaseData implements JSObject { @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void setCallbackFloat(String key, FloatCallback value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") + public native void setCallbackReflective(String key, ReflectiveObjectCallback value); + + @JSBody(params = { "key", "value" }, script = "this[key]=value;") + public native void setCallbackReflectiveWithDataArg(String key, DataReflectiveObjectCallback value); + @JSBody(params = { "key", "value" }, script = "this[key]=value;") public native void setCallbackObject(String key, ObjectCallback value); @@ -300,6 +333,9 @@ public abstract class BaseData implements JSObject { @JSBody(params = { "key" }, script = "return this[key];") public native JSObject getObject(String key); + @JSBody(params = { "key" }, script = "return this[key];") + public native Object getReflective(String key); + @JSBody(params = { "key" }, script = "return this[key];") public native BaseData getBaseData(String key); @@ -357,4 +393,4 @@ public abstract class BaseData implements JSObject { @JSBody(params = { }, script = "if(this.getRef){ return this.getRef(); } else { return null; }") public native BaseData getRef(); -} \ No newline at end of file +} diff --git a/sources/main/java/net/eaglerforge/api/ModAPI.java b/sources/main/java/net/eaglerforge/api/ModAPI.java index b50299a..774ff43 100644 --- a/sources/main/java/net/eaglerforge/api/ModAPI.java +++ b/sources/main/java/net/eaglerforge/api/ModAPI.java @@ -1,6 +1,7 @@ package net.eaglerforge.api; import net.eaglerforge.gui.ModGUI; +import net.eaglerforge.reflect.PLReflect; import net.lax1dude.eaglercraft.v1_8.EagRuntime; import net.lax1dude.eaglercraft.v1_8.log4j.LogManager; import net.lax1dude.eaglercraft.v1_8.log4j.Logger; @@ -310,6 +311,7 @@ public class ModAPI { setGlobal("mcinstance", mc); setMinecraftContext(mc); setGlobal("platform", PlatformAPI.makeModData()); + setGlobal("reflect", PLReflect.makeModData()); setGlobal("logger", LoggerAPI.makeModData()); //setGlobal("emptygui", EmptyGui.makeModData()); setGlobal("ScaledResolution", ScaledResolution.makeModData()); diff --git a/sources/main/java/net/eaglerforge/api/ModData.java b/sources/main/java/net/eaglerforge/api/ModData.java index fc7ea07..e2a560c 100644 --- a/sources/main/java/net/eaglerforge/api/ModData.java +++ b/sources/main/java/net/eaglerforge/api/ModData.java @@ -1,4 +1,4 @@ package net.eaglerforge.api; -public class ModData extends BaseData{ +public class ModData extends BaseData { } diff --git a/sources/main/java/net/eaglerforge/reflect/PLReflect.java b/sources/main/java/net/eaglerforge/reflect/PLReflect.java new file mode 100644 index 0000000..d056290 --- /dev/null +++ b/sources/main/java/net/eaglerforge/reflect/PLReflect.java @@ -0,0 +1,2483 @@ +package net.eaglerforge.reflect; + +import net.minecraft.world.storage.ISaveFormat; +import net.minecraft.client.resources.model.ModelManager; +import net.minecraft.util.FrameTimer; +import net.minecraft.client.renderer.ItemRenderer; +import net.minecraft.client.renderer.entity.RenderItem; +import net.minecraft.client.renderer.entity.RenderManager; +import net.minecraft.client.renderer.BlockRendererDispatcher; +import net.minecraft.client.audio.SoundHandler; +import net.minecraft.client.renderer.texture.TextureMap; +import net.minecraft.client.resources.LanguageManager; +import net.minecraft.client.resources.ResourcePackRepository; +import net.minecraft.client.resources.IResourceManager; +import net.minecraft.client.renderer.texture.TextureManager; +import net.minecraft.util.Session; +import net.minecraft.client.multiplayer.ServerData; +import net.minecraft.client.Minecraft; +import net.minecraft.client.network.NetHandlerPlayClient; +import net.minecraft.client.multiplayer.WorldClient; +import net.minecraft.world.WorldSettings; +import net.minecraft.client.audio.MusicTicker; +import net.minecraft.client.gui.GuiScreen; +import net.minecraft.crash.CrashReport; +import net.minecraft.client.main.GameConfiguration; +import net.minecraft.util.IChatComponent; +import net.minecraft.entity.item.EntityItemFrame; +import net.minecraft.nbt.NBTBase; +import net.minecraft.enchantment.Enchantment; +import net.minecraft.item.EnumRarity; +import net.minecraft.nbt.NBTTagList; +import net.minecraft.item.EnumAction; +import net.minecraft.entity.Entity; +import net.minecraft.util.BlockPos; +import net.minecraft.entity.EntityLivingBase; +import net.lax1dude.eaglercraft.v1_8.EaglercraftRandom; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.world.World; +import net.minecraft.nbt.NBTTagCompound; +import net.eaglerforge.api.ModData; +import net.minecraft.item.ItemStack; +import net.eaglerforge.api.BaseData; +import net.minecraft.item.Item; +import net.minecraft.block.Block; +import java.lang.String; +import net.minecraft.client.Minecraft; +import net.minecraft.item.ItemStack; +import net.eaglerforge.EaglerForge; + +import net.eaglerforge.api.*; +import java.util.ArrayList; +import java.lang.Exception; +import org.teavm.jso.JSBody; +import org.teavm.jso.JSObject; +import org.teavm.jso.JSFunctor; + +//AUTOGENERATED BY NOREFLECT +//Made by ZXMushroom63 + +public class PLReflect extends ModData { + public static PLReflect makeModData() { + PLReflect plReflectGlobal = new PLReflect(); + ArrayList reflectProfiles = new ArrayList(); + + // CLASSDEF FOR ItemStack + BaseData reflect_ItemStack = new ModData(); + + ArrayList reflect_ItemStack_constructors = new ArrayList(); + + BaseData reflect_ItemStack_constructor_ItemStack_0 = new ModData(); + reflect_ItemStack_constructor_ItemStack_0.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_0.set("argnames", new String[] { "blockIn" }); + reflect_ItemStack_constructor_ItemStack_0.set("argtypes", new String[] { "Block" }); + reflect_ItemStack_constructor_ItemStack_0.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Block) params.getReflective("blockIn")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_0); + + BaseData reflect_ItemStack_constructor_ItemStack_1 = new ModData(); + reflect_ItemStack_constructor_ItemStack_1.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_1.set("argnames", new String[] { "blockIn", "amount" }); + reflect_ItemStack_constructor_ItemStack_1.set("argtypes", new String[] { "Block", "int" }); + reflect_ItemStack_constructor_ItemStack_1.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Block) params.getReflective("blockIn"), (int) params.getInt("amount")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_1); + + BaseData reflect_ItemStack_constructor_ItemStack_2 = new ModData(); + reflect_ItemStack_constructor_ItemStack_2.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_2.set("argnames", new String[] { "blockIn", "amount", "meta" }); + reflect_ItemStack_constructor_ItemStack_2.set("argtypes", new String[] { "Block", "int", "int" }); + reflect_ItemStack_constructor_ItemStack_2.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Block) params.getReflective("blockIn"), (int) params.getInt("amount"), + (int) params.getInt("meta")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_2); + + BaseData reflect_ItemStack_constructor_ItemStack_3 = new ModData(); + reflect_ItemStack_constructor_ItemStack_3.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_3.set("argnames", new String[] { "itemIn" }); + reflect_ItemStack_constructor_ItemStack_3.set("argtypes", new String[] { "Item" }); + reflect_ItemStack_constructor_ItemStack_3.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Item) params.getReflective("itemIn")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_3); + + BaseData reflect_ItemStack_constructor_ItemStack_4 = new ModData(); + reflect_ItemStack_constructor_ItemStack_4.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_4.set("argnames", new String[] { "itemIn", "amount" }); + reflect_ItemStack_constructor_ItemStack_4.set("argtypes", new String[] { "Item", "int" }); + reflect_ItemStack_constructor_ItemStack_4.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Item) params.getReflective("itemIn"), (int) params.getInt("amount")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_4); + + BaseData reflect_ItemStack_constructor_ItemStack_5 = new ModData(); + reflect_ItemStack_constructor_ItemStack_5.set("returnType", "ItemStack"); + reflect_ItemStack_constructor_ItemStack_5.set("argnames", new String[] { "itemIn", "amount", "meta" }); + reflect_ItemStack_constructor_ItemStack_5.set("argtypes", new String[] { "Item", "int", "int" }); + reflect_ItemStack_constructor_ItemStack_5.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new ItemStack((Item) params.getReflective("itemIn"), (int) params.getInt("amount"), + (int) params.getInt("meta")); + }); + + reflect_ItemStack_constructors.add(reflect_ItemStack_constructor_ItemStack_5); + + BaseData[] reflect_ItemStack_constructors_arr = new BaseData[reflect_ItemStack_constructors.size()]; + for (int i = 0; i < reflect_ItemStack_constructors_arr.length; i++) { + reflect_ItemStack_constructors_arr[i] = reflect_ItemStack_constructors.get(i); + } + + ArrayList reflect_ItemStack_methods = new ArrayList(); + + BaseData reflect_ItemStack_method_loadModData_0 = new ModData(); + reflect_ItemStack_method_loadModData_0.set("methodName", "loadModData"); + reflect_ItemStack_method_loadModData_0.set("returnType", "ItemStack"); + reflect_ItemStack_method_loadModData_0.set("static", false); + reflect_ItemStack_method_loadModData_0.set("argnames", new String[] { "data" }); + reflect_ItemStack_method_loadModData_0.set("argtypes", new String[] { "BaseData" }); + reflect_ItemStack_method_loadModData_0.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).loadModData((BaseData) params.getReflective("data")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_loadModData_0); + + BaseData reflect_ItemStack_method_fromModData_1 = new ModData(); + reflect_ItemStack_method_fromModData_1.set("methodName", "fromModData"); + reflect_ItemStack_method_fromModData_1.set("returnType", "ItemStack"); + reflect_ItemStack_method_fromModData_1.set("static", true); + reflect_ItemStack_method_fromModData_1.set("argnames", new String[] { "data" }); + reflect_ItemStack_method_fromModData_1.set("argtypes", new String[] { "BaseData" }); + reflect_ItemStack_method_fromModData_1.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ItemStack.fromModData((BaseData) params.getReflective("data")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_fromModData_1); + + BaseData reflect_ItemStack_method_makeModData_2 = new ModData(); + reflect_ItemStack_method_makeModData_2.set("methodName", "makeModData"); + reflect_ItemStack_method_makeModData_2.set("returnType", "ItemStack"); + reflect_ItemStack_method_makeModData_2.set("static", false); + reflect_ItemStack_method_makeModData_2.set("argnames", new String[] {}); + reflect_ItemStack_method_makeModData_2.set("argtypes", new String[] {}); + reflect_ItemStack_method_makeModData_2.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ModData) ((ItemStack) params.getReflective("_self")).makeModData(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_makeModData_2); + + BaseData reflect_ItemStack_method_loadItemStackFromNBT_3 = new ModData(); + reflect_ItemStack_method_loadItemStackFromNBT_3.set("methodName", "loadItemStackFromNBT"); + reflect_ItemStack_method_loadItemStackFromNBT_3.set("returnType", "ItemStack"); + reflect_ItemStack_method_loadItemStackFromNBT_3.set("static", true); + reflect_ItemStack_method_loadItemStackFromNBT_3.set("argnames", new String[] { "nbt" }); + reflect_ItemStack_method_loadItemStackFromNBT_3.set("argtypes", new String[] { "NBTTagCompound" }); + reflect_ItemStack_method_loadItemStackFromNBT_3.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ItemStack.loadItemStackFromNBT((NBTTagCompound) params.getReflective("nbt")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_loadItemStackFromNBT_3); + + BaseData reflect_ItemStack_method_splitStack_4 = new ModData(); + reflect_ItemStack_method_splitStack_4.set("methodName", "splitStack"); + reflect_ItemStack_method_splitStack_4.set("returnType", "ItemStack"); + reflect_ItemStack_method_splitStack_4.set("static", false); + reflect_ItemStack_method_splitStack_4.set("argnames", new String[] { "amount" }); + reflect_ItemStack_method_splitStack_4.set("argtypes", new String[] { "int" }); + reflect_ItemStack_method_splitStack_4.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ((ItemStack) params.getReflective("_self")) + .splitStack((int) params.getInt("amount")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_splitStack_4); + + BaseData reflect_ItemStack_method_getItem_5 = new ModData(); + reflect_ItemStack_method_getItem_5.set("methodName", "getItem"); + reflect_ItemStack_method_getItem_5.set("returnType", "ItemStack"); + reflect_ItemStack_method_getItem_5.set("static", false); + reflect_ItemStack_method_getItem_5.set("argnames", new String[] {}); + reflect_ItemStack_method_getItem_5.set("argtypes", new String[] {}); + reflect_ItemStack_method_getItem_5.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (Item) ((ItemStack) params.getReflective("_self")).getItem(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getItem_5); + + BaseData reflect_ItemStack_method_getStrVsBlock_6 = new ModData(); + reflect_ItemStack_method_getStrVsBlock_6.set("methodName", "getStrVsBlock"); + reflect_ItemStack_method_getStrVsBlock_6.set("returnType", "ItemStack"); + reflect_ItemStack_method_getStrVsBlock_6.set("static", false); + reflect_ItemStack_method_getStrVsBlock_6.set("argnames", new String[] { "blockIn" }); + reflect_ItemStack_method_getStrVsBlock_6.set("argtypes", new String[] { "Block" }); + reflect_ItemStack_method_getStrVsBlock_6.setCallbackFloatWithDataArg("exec", (BaseData params) -> { + try { + return (float) ((ItemStack) params.getReflective("_self")) + .getStrVsBlock((Block) params.getReflective("blockIn")); + } catch (Exception _exception_reflect_) { + return 0.0f; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getStrVsBlock_6); + + BaseData reflect_ItemStack_method_useItemRightClick_7 = new ModData(); + reflect_ItemStack_method_useItemRightClick_7.set("methodName", "useItemRightClick"); + reflect_ItemStack_method_useItemRightClick_7.set("returnType", "ItemStack"); + reflect_ItemStack_method_useItemRightClick_7.set("static", false); + reflect_ItemStack_method_useItemRightClick_7.set("argnames", new String[] { "worldIn", "playerIn" }); + reflect_ItemStack_method_useItemRightClick_7.set("argtypes", new String[] { "World", "EntityPlayer" }); + reflect_ItemStack_method_useItemRightClick_7.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ((ItemStack) params.getReflective("_self")).useItemRightClick( + (World) params.getReflective("worldIn"), (EntityPlayer) params.getReflective("playerIn")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_useItemRightClick_7); + + BaseData reflect_ItemStack_method_onItemUseFinish_8 = new ModData(); + reflect_ItemStack_method_onItemUseFinish_8.set("methodName", "onItemUseFinish"); + reflect_ItemStack_method_onItemUseFinish_8.set("returnType", "ItemStack"); + reflect_ItemStack_method_onItemUseFinish_8.set("static", false); + reflect_ItemStack_method_onItemUseFinish_8.set("argnames", new String[] { "worldIn", "playerIn" }); + reflect_ItemStack_method_onItemUseFinish_8.set("argtypes", new String[] { "World", "EntityPlayer" }); + reflect_ItemStack_method_onItemUseFinish_8.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ((ItemStack) params.getReflective("_self")).onItemUseFinish( + (World) params.getReflective("worldIn"), (EntityPlayer) params.getReflective("playerIn")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_onItemUseFinish_8); + + BaseData reflect_ItemStack_method_writeToNBT_9 = new ModData(); + reflect_ItemStack_method_writeToNBT_9.set("methodName", "writeToNBT"); + reflect_ItemStack_method_writeToNBT_9.set("returnType", "ItemStack"); + reflect_ItemStack_method_writeToNBT_9.set("static", false); + reflect_ItemStack_method_writeToNBT_9.set("argnames", new String[] { "nbt" }); + reflect_ItemStack_method_writeToNBT_9.set("argtypes", new String[] { "NBTTagCompound" }); + reflect_ItemStack_method_writeToNBT_9.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (NBTTagCompound) ((ItemStack) params.getReflective("_self")) + .writeToNBT((NBTTagCompound) params.getReflective("nbt")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_writeToNBT_9); + + BaseData reflect_ItemStack_method_toNBT_10 = new ModData(); + reflect_ItemStack_method_toNBT_10.set("methodName", "toNBT"); + reflect_ItemStack_method_toNBT_10.set("returnType", "ItemStack"); + reflect_ItemStack_method_toNBT_10.set("static", false); + reflect_ItemStack_method_toNBT_10.set("argnames", new String[] {}); + reflect_ItemStack_method_toNBT_10.set("argtypes", new String[] {}); + reflect_ItemStack_method_toNBT_10.setCallbackStringWithDataArg("exec", (BaseData params) -> { + try { + return (String) ((ItemStack) params.getReflective("_self")).toNBT(); + } catch (Exception _exception_reflect_) { + return ""; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_toNBT_10); + + BaseData reflect_ItemStack_method_fromNBT_11 = new ModData(); + reflect_ItemStack_method_fromNBT_11.set("methodName", "fromNBT"); + reflect_ItemStack_method_fromNBT_11.set("returnType", "ItemStack"); + reflect_ItemStack_method_fromNBT_11.set("static", false); + reflect_ItemStack_method_fromNBT_11.set("argnames", new String[] { "nbt" }); + reflect_ItemStack_method_fromNBT_11.set("argtypes", new String[] { "String" }); + reflect_ItemStack_method_fromNBT_11.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).fromNBT((String) params.getString("nbt")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_fromNBT_11); + + BaseData reflect_ItemStack_method_readFromNBT_12 = new ModData(); + reflect_ItemStack_method_readFromNBT_12.set("methodName", "readFromNBT"); + reflect_ItemStack_method_readFromNBT_12.set("returnType", "ItemStack"); + reflect_ItemStack_method_readFromNBT_12.set("static", false); + reflect_ItemStack_method_readFromNBT_12.set("argnames", new String[] { "nbt" }); + reflect_ItemStack_method_readFromNBT_12.set("argtypes", new String[] { "NBTTagCompound" }); + reflect_ItemStack_method_readFromNBT_12.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).readFromNBT((NBTTagCompound) params.getReflective("nbt")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_readFromNBT_12); + + BaseData reflect_ItemStack_method_getMaxStackSize_13 = new ModData(); + reflect_ItemStack_method_getMaxStackSize_13.set("methodName", "getMaxStackSize"); + reflect_ItemStack_method_getMaxStackSize_13.set("returnType", "ItemStack"); + reflect_ItemStack_method_getMaxStackSize_13.set("static", false); + reflect_ItemStack_method_getMaxStackSize_13.set("argnames", new String[] {}); + reflect_ItemStack_method_getMaxStackSize_13.set("argtypes", new String[] {}); + reflect_ItemStack_method_getMaxStackSize_13.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getMaxStackSize(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getMaxStackSize_13); + + BaseData reflect_ItemStack_method_isStackable_14 = new ModData(); + reflect_ItemStack_method_isStackable_14.set("methodName", "isStackable"); + reflect_ItemStack_method_isStackable_14.set("returnType", "ItemStack"); + reflect_ItemStack_method_isStackable_14.set("static", false); + reflect_ItemStack_method_isStackable_14.set("argnames", new String[] {}); + reflect_ItemStack_method_isStackable_14.set("argtypes", new String[] {}); + reflect_ItemStack_method_isStackable_14.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isStackable(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isStackable_14); + + BaseData reflect_ItemStack_method_isItemStackDamageable_15 = new ModData(); + reflect_ItemStack_method_isItemStackDamageable_15.set("methodName", "isItemStackDamageable"); + reflect_ItemStack_method_isItemStackDamageable_15.set("returnType", "ItemStack"); + reflect_ItemStack_method_isItemStackDamageable_15.set("static", false); + reflect_ItemStack_method_isItemStackDamageable_15.set("argnames", new String[] {}); + reflect_ItemStack_method_isItemStackDamageable_15.set("argtypes", new String[] {}); + reflect_ItemStack_method_isItemStackDamageable_15.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isItemStackDamageable(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isItemStackDamageable_15); + + BaseData reflect_ItemStack_method_getHasSubtypes_16 = new ModData(); + reflect_ItemStack_method_getHasSubtypes_16.set("methodName", "getHasSubtypes"); + reflect_ItemStack_method_getHasSubtypes_16.set("returnType", "ItemStack"); + reflect_ItemStack_method_getHasSubtypes_16.set("static", false); + reflect_ItemStack_method_getHasSubtypes_16.set("argnames", new String[] {}); + reflect_ItemStack_method_getHasSubtypes_16.set("argtypes", new String[] {}); + reflect_ItemStack_method_getHasSubtypes_16.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).getHasSubtypes(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getHasSubtypes_16); + + BaseData reflect_ItemStack_method_isItemDamaged_17 = new ModData(); + reflect_ItemStack_method_isItemDamaged_17.set("methodName", "isItemDamaged"); + reflect_ItemStack_method_isItemDamaged_17.set("returnType", "ItemStack"); + reflect_ItemStack_method_isItemDamaged_17.set("static", false); + reflect_ItemStack_method_isItemDamaged_17.set("argnames", new String[] {}); + reflect_ItemStack_method_isItemDamaged_17.set("argtypes", new String[] {}); + reflect_ItemStack_method_isItemDamaged_17.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isItemDamaged(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isItemDamaged_17); + + BaseData reflect_ItemStack_method_getItemDamage_18 = new ModData(); + reflect_ItemStack_method_getItemDamage_18.set("methodName", "getItemDamage"); + reflect_ItemStack_method_getItemDamage_18.set("returnType", "ItemStack"); + reflect_ItemStack_method_getItemDamage_18.set("static", false); + reflect_ItemStack_method_getItemDamage_18.set("argnames", new String[] {}); + reflect_ItemStack_method_getItemDamage_18.set("argtypes", new String[] {}); + reflect_ItemStack_method_getItemDamage_18.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getItemDamage(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getItemDamage_18); + + BaseData reflect_ItemStack_method_getMetadata_19 = new ModData(); + reflect_ItemStack_method_getMetadata_19.set("methodName", "getMetadata"); + reflect_ItemStack_method_getMetadata_19.set("returnType", "ItemStack"); + reflect_ItemStack_method_getMetadata_19.set("static", false); + reflect_ItemStack_method_getMetadata_19.set("argnames", new String[] {}); + reflect_ItemStack_method_getMetadata_19.set("argtypes", new String[] {}); + reflect_ItemStack_method_getMetadata_19.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getMetadata(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getMetadata_19); + + BaseData reflect_ItemStack_method_setItemDamage_20 = new ModData(); + reflect_ItemStack_method_setItemDamage_20.set("methodName", "setItemDamage"); + reflect_ItemStack_method_setItemDamage_20.set("returnType", "ItemStack"); + reflect_ItemStack_method_setItemDamage_20.set("static", false); + reflect_ItemStack_method_setItemDamage_20.set("argnames", new String[] { "meta" }); + reflect_ItemStack_method_setItemDamage_20.set("argtypes", new String[] { "int" }); + reflect_ItemStack_method_setItemDamage_20.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).setItemDamage((int) params.getInt("meta")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setItemDamage_20); + + BaseData reflect_ItemStack_method_getMaxDamage_21 = new ModData(); + reflect_ItemStack_method_getMaxDamage_21.set("methodName", "getMaxDamage"); + reflect_ItemStack_method_getMaxDamage_21.set("returnType", "ItemStack"); + reflect_ItemStack_method_getMaxDamage_21.set("static", false); + reflect_ItemStack_method_getMaxDamage_21.set("argnames", new String[] {}); + reflect_ItemStack_method_getMaxDamage_21.set("argtypes", new String[] {}); + reflect_ItemStack_method_getMaxDamage_21.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getMaxDamage(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getMaxDamage_21); + + BaseData reflect_ItemStack_method_attemptDamageItem_22 = new ModData(); + reflect_ItemStack_method_attemptDamageItem_22.set("methodName", "attemptDamageItem"); + reflect_ItemStack_method_attemptDamageItem_22.set("returnType", "ItemStack"); + reflect_ItemStack_method_attemptDamageItem_22.set("static", false); + reflect_ItemStack_method_attemptDamageItem_22.set("argnames", new String[] { "amount", "rand" }); + reflect_ItemStack_method_attemptDamageItem_22.set("argtypes", new String[] { "int", "EaglercraftRandom" }); + reflect_ItemStack_method_attemptDamageItem_22.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).attemptDamageItem( + (int) params.getInt("amount"), (EaglercraftRandom) params.getReflective("rand")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_attemptDamageItem_22); + + BaseData reflect_ItemStack_method_damageItem_23 = new ModData(); + reflect_ItemStack_method_damageItem_23.set("methodName", "damageItem"); + reflect_ItemStack_method_damageItem_23.set("returnType", "ItemStack"); + reflect_ItemStack_method_damageItem_23.set("static", false); + reflect_ItemStack_method_damageItem_23.set("argnames", new String[] { "amount", "entityIn" }); + reflect_ItemStack_method_damageItem_23.set("argtypes", new String[] { "int", "EntityLivingBase" }); + reflect_ItemStack_method_damageItem_23.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).damageItem((int) params.getInt("amount"), + (EntityLivingBase) params.getReflective("entityIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_damageItem_23); + + BaseData reflect_ItemStack_method_hitEntity_24 = new ModData(); + reflect_ItemStack_method_hitEntity_24.set("methodName", "hitEntity"); + reflect_ItemStack_method_hitEntity_24.set("returnType", "ItemStack"); + reflect_ItemStack_method_hitEntity_24.set("static", false); + reflect_ItemStack_method_hitEntity_24.set("argnames", new String[] { "entityIn", "playerIn" }); + reflect_ItemStack_method_hitEntity_24.set("argtypes", new String[] { "EntityLivingBase", "EntityPlayer" }); + reflect_ItemStack_method_hitEntity_24.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).hitEntity( + (EntityLivingBase) params.getReflective("entityIn"), + (EntityPlayer) params.getReflective("playerIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_hitEntity_24); + + BaseData reflect_ItemStack_method_onBlockDestroyed_25 = new ModData(); + reflect_ItemStack_method_onBlockDestroyed_25.set("methodName", "onBlockDestroyed"); + reflect_ItemStack_method_onBlockDestroyed_25.set("returnType", "ItemStack"); + reflect_ItemStack_method_onBlockDestroyed_25.set("static", false); + reflect_ItemStack_method_onBlockDestroyed_25.set("argnames", + new String[] { "worldIn", "blockIn", "pos", "playerIn" }); + reflect_ItemStack_method_onBlockDestroyed_25.set("argtypes", + new String[] { "World", "Block", "BlockPos", "EntityPlayer" }); + reflect_ItemStack_method_onBlockDestroyed_25.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).onBlockDestroyed((World) params.getReflective("worldIn"), + (Block) params.getReflective("blockIn"), (BlockPos) params.getReflective("pos"), + (EntityPlayer) params.getReflective("playerIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_onBlockDestroyed_25); + + BaseData reflect_ItemStack_method_canHarvestBlock_26 = new ModData(); + reflect_ItemStack_method_canHarvestBlock_26.set("methodName", "canHarvestBlock"); + reflect_ItemStack_method_canHarvestBlock_26.set("returnType", "ItemStack"); + reflect_ItemStack_method_canHarvestBlock_26.set("static", false); + reflect_ItemStack_method_canHarvestBlock_26.set("argnames", new String[] { "blockIn" }); + reflect_ItemStack_method_canHarvestBlock_26.set("argtypes", new String[] { "Block" }); + reflect_ItemStack_method_canHarvestBlock_26.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")) + .canHarvestBlock((Block) params.getReflective("blockIn")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_canHarvestBlock_26); + + BaseData reflect_ItemStack_method_interactWithEntity_27 = new ModData(); + reflect_ItemStack_method_interactWithEntity_27.set("methodName", "interactWithEntity"); + reflect_ItemStack_method_interactWithEntity_27.set("returnType", "ItemStack"); + reflect_ItemStack_method_interactWithEntity_27.set("static", false); + reflect_ItemStack_method_interactWithEntity_27.set("argnames", new String[] { "playerIn", "entityIn" }); + reflect_ItemStack_method_interactWithEntity_27.set("argtypes", + new String[] { "EntityPlayer", "EntityLivingBase" }); + reflect_ItemStack_method_interactWithEntity_27.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).interactWithEntity( + (EntityPlayer) params.getReflective("playerIn"), + (EntityLivingBase) params.getReflective("entityIn")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_interactWithEntity_27); + + BaseData reflect_ItemStack_method_copy_28 = new ModData(); + reflect_ItemStack_method_copy_28.set("methodName", "copy"); + reflect_ItemStack_method_copy_28.set("returnType", "ItemStack"); + reflect_ItemStack_method_copy_28.set("static", false); + reflect_ItemStack_method_copy_28.set("argnames", new String[] {}); + reflect_ItemStack_method_copy_28.set("argtypes", new String[] {}); + reflect_ItemStack_method_copy_28.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ((ItemStack) params.getReflective("_self")).copy(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_copy_28); + + BaseData reflect_ItemStack_method_areItemStackTagsEqual_29 = new ModData(); + reflect_ItemStack_method_areItemStackTagsEqual_29.set("methodName", "areItemStackTagsEqual"); + reflect_ItemStack_method_areItemStackTagsEqual_29.set("returnType", "ItemStack"); + reflect_ItemStack_method_areItemStackTagsEqual_29.set("static", true); + reflect_ItemStack_method_areItemStackTagsEqual_29.set("argnames", new String[] { "stackA", "stackB" }); + reflect_ItemStack_method_areItemStackTagsEqual_29.set("argtypes", new String[] { "ItemStack", "ItemStack" }); + reflect_ItemStack_method_areItemStackTagsEqual_29.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ItemStack.areItemStackTagsEqual((ItemStack) params.getReflective("stackA"), + (ItemStack) params.getReflective("stackB")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_areItemStackTagsEqual_29); + + BaseData reflect_ItemStack_method_areItemStacksEqual_30 = new ModData(); + reflect_ItemStack_method_areItemStacksEqual_30.set("methodName", "areItemStacksEqual"); + reflect_ItemStack_method_areItemStacksEqual_30.set("returnType", "ItemStack"); + reflect_ItemStack_method_areItemStacksEqual_30.set("static", true); + reflect_ItemStack_method_areItemStacksEqual_30.set("argnames", new String[] { "stackA", "stackB" }); + reflect_ItemStack_method_areItemStacksEqual_30.set("argtypes", new String[] { "ItemStack", "ItemStack" }); + reflect_ItemStack_method_areItemStacksEqual_30.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ItemStack.areItemStacksEqual((ItemStack) params.getReflective("stackA"), + (ItemStack) params.getReflective("stackB")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_areItemStacksEqual_30); + + BaseData reflect_ItemStack_method_areItemsEqual_31 = new ModData(); + reflect_ItemStack_method_areItemsEqual_31.set("methodName", "areItemsEqual"); + reflect_ItemStack_method_areItemsEqual_31.set("returnType", "ItemStack"); + reflect_ItemStack_method_areItemsEqual_31.set("static", true); + reflect_ItemStack_method_areItemsEqual_31.set("argnames", new String[] { "stackA", "stackB" }); + reflect_ItemStack_method_areItemsEqual_31.set("argtypes", new String[] { "ItemStack", "ItemStack" }); + reflect_ItemStack_method_areItemsEqual_31.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ItemStack.areItemsEqual((ItemStack) params.getReflective("stackA"), + (ItemStack) params.getReflective("stackB")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_areItemsEqual_31); + + BaseData reflect_ItemStack_method_isItemEqual_32 = new ModData(); + reflect_ItemStack_method_isItemEqual_32.set("methodName", "isItemEqual"); + reflect_ItemStack_method_isItemEqual_32.set("returnType", "ItemStack"); + reflect_ItemStack_method_isItemEqual_32.set("static", false); + reflect_ItemStack_method_isItemEqual_32.set("argnames", new String[] { "other" }); + reflect_ItemStack_method_isItemEqual_32.set("argtypes", new String[] { "ItemStack" }); + reflect_ItemStack_method_isItemEqual_32.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")) + .isItemEqual((ItemStack) params.getReflective("other")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isItemEqual_32); + + BaseData reflect_ItemStack_method_getUnlocalizedName_33 = new ModData(); + reflect_ItemStack_method_getUnlocalizedName_33.set("methodName", "getUnlocalizedName"); + reflect_ItemStack_method_getUnlocalizedName_33.set("returnType", "ItemStack"); + reflect_ItemStack_method_getUnlocalizedName_33.set("static", false); + reflect_ItemStack_method_getUnlocalizedName_33.set("argnames", new String[] {}); + reflect_ItemStack_method_getUnlocalizedName_33.set("argtypes", new String[] {}); + reflect_ItemStack_method_getUnlocalizedName_33.setCallbackStringWithDataArg("exec", (BaseData params) -> { + try { + return (String) ((ItemStack) params.getReflective("_self")).getUnlocalizedName(); + } catch (Exception _exception_reflect_) { + return ""; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getUnlocalizedName_33); + + BaseData reflect_ItemStack_method_copyItemStack_34 = new ModData(); + reflect_ItemStack_method_copyItemStack_34.set("methodName", "copyItemStack"); + reflect_ItemStack_method_copyItemStack_34.set("returnType", "ItemStack"); + reflect_ItemStack_method_copyItemStack_34.set("static", true); + reflect_ItemStack_method_copyItemStack_34.set("argnames", new String[] { "stack" }); + reflect_ItemStack_method_copyItemStack_34.set("argtypes", new String[] { "ItemStack" }); + reflect_ItemStack_method_copyItemStack_34.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ItemStack.copyItemStack((ItemStack) params.getReflective("stack")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_copyItemStack_34); + + BaseData reflect_ItemStack_method_toString_35 = new ModData(); + reflect_ItemStack_method_toString_35.set("methodName", "toString"); + reflect_ItemStack_method_toString_35.set("returnType", "ItemStack"); + reflect_ItemStack_method_toString_35.set("static", false); + reflect_ItemStack_method_toString_35.set("argnames", new String[] {}); + reflect_ItemStack_method_toString_35.set("argtypes", new String[] {}); + reflect_ItemStack_method_toString_35.setCallbackStringWithDataArg("exec", (BaseData params) -> { + try { + return (String) ((ItemStack) params.getReflective("_self")).toString(); + } catch (Exception _exception_reflect_) { + return ""; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_toString_35); + + BaseData reflect_ItemStack_method_updateAnimation_36 = new ModData(); + reflect_ItemStack_method_updateAnimation_36.set("methodName", "updateAnimation"); + reflect_ItemStack_method_updateAnimation_36.set("returnType", "ItemStack"); + reflect_ItemStack_method_updateAnimation_36.set("static", false); + reflect_ItemStack_method_updateAnimation_36.set("argnames", + new String[] { "worldIn", "entityIn", "inventorySlot", "isCurrentItem" }); + reflect_ItemStack_method_updateAnimation_36.set("argtypes", + new String[] { "World", "Entity", "int", "boolean" }); + reflect_ItemStack_method_updateAnimation_36.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).updateAnimation((World) params.getReflective("worldIn"), + (Entity) params.getReflective("entityIn"), (int) params.getInt("inventorySlot"), + (boolean) params.getBoolean("isCurrentItem")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_updateAnimation_36); + + BaseData reflect_ItemStack_method_onCrafting_37 = new ModData(); + reflect_ItemStack_method_onCrafting_37.set("methodName", "onCrafting"); + reflect_ItemStack_method_onCrafting_37.set("returnType", "ItemStack"); + reflect_ItemStack_method_onCrafting_37.set("static", false); + reflect_ItemStack_method_onCrafting_37.set("argnames", new String[] { "worldIn", "playerIn", "amount" }); + reflect_ItemStack_method_onCrafting_37.set("argtypes", new String[] { "World", "EntityPlayer", "int" }); + reflect_ItemStack_method_onCrafting_37.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).onCrafting((World) params.getReflective("worldIn"), + (EntityPlayer) params.getReflective("playerIn"), (int) params.getInt("amount")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_onCrafting_37); + + BaseData reflect_ItemStack_method_getIsItemStackEqual_38 = new ModData(); + reflect_ItemStack_method_getIsItemStackEqual_38.set("methodName", "getIsItemStackEqual"); + reflect_ItemStack_method_getIsItemStackEqual_38.set("returnType", "ItemStack"); + reflect_ItemStack_method_getIsItemStackEqual_38.set("static", false); + reflect_ItemStack_method_getIsItemStackEqual_38.set("argnames", new String[] { "parItemStack" }); + reflect_ItemStack_method_getIsItemStackEqual_38.set("argtypes", new String[] { "ItemStack" }); + reflect_ItemStack_method_getIsItemStackEqual_38.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")) + .getIsItemStackEqual((ItemStack) params.getReflective("parItemStack")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getIsItemStackEqual_38); + + BaseData reflect_ItemStack_method_getMaxItemUseDuration_39 = new ModData(); + reflect_ItemStack_method_getMaxItemUseDuration_39.set("methodName", "getMaxItemUseDuration"); + reflect_ItemStack_method_getMaxItemUseDuration_39.set("returnType", "ItemStack"); + reflect_ItemStack_method_getMaxItemUseDuration_39.set("static", false); + reflect_ItemStack_method_getMaxItemUseDuration_39.set("argnames", new String[] {}); + reflect_ItemStack_method_getMaxItemUseDuration_39.set("argtypes", new String[] {}); + reflect_ItemStack_method_getMaxItemUseDuration_39.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getMaxItemUseDuration(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getMaxItemUseDuration_39); + + BaseData reflect_ItemStack_method_getItemUseAction_40 = new ModData(); + reflect_ItemStack_method_getItemUseAction_40.set("methodName", "getItemUseAction"); + reflect_ItemStack_method_getItemUseAction_40.set("returnType", "ItemStack"); + reflect_ItemStack_method_getItemUseAction_40.set("static", false); + reflect_ItemStack_method_getItemUseAction_40.set("argnames", new String[] {}); + reflect_ItemStack_method_getItemUseAction_40.set("argtypes", new String[] {}); + reflect_ItemStack_method_getItemUseAction_40.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (EnumAction) ((ItemStack) params.getReflective("_self")).getItemUseAction(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getItemUseAction_40); + + BaseData reflect_ItemStack_method_onPlayerStoppedUsing_41 = new ModData(); + reflect_ItemStack_method_onPlayerStoppedUsing_41.set("methodName", "onPlayerStoppedUsing"); + reflect_ItemStack_method_onPlayerStoppedUsing_41.set("returnType", "ItemStack"); + reflect_ItemStack_method_onPlayerStoppedUsing_41.set("static", false); + reflect_ItemStack_method_onPlayerStoppedUsing_41.set("argnames", + new String[] { "worldIn", "playerIn", "timeLeft" }); + reflect_ItemStack_method_onPlayerStoppedUsing_41.set("argtypes", + new String[] { "World", "EntityPlayer", "int" }); + reflect_ItemStack_method_onPlayerStoppedUsing_41.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).onPlayerStoppedUsing( + (World) params.getReflective("worldIn"), (EntityPlayer) params.getReflective("playerIn"), + (int) params.getInt("timeLeft")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_onPlayerStoppedUsing_41); + + BaseData reflect_ItemStack_method_hasTagCompound_42 = new ModData(); + reflect_ItemStack_method_hasTagCompound_42.set("methodName", "hasTagCompound"); + reflect_ItemStack_method_hasTagCompound_42.set("returnType", "ItemStack"); + reflect_ItemStack_method_hasTagCompound_42.set("static", false); + reflect_ItemStack_method_hasTagCompound_42.set("argnames", new String[] {}); + reflect_ItemStack_method_hasTagCompound_42.set("argtypes", new String[] {}); + reflect_ItemStack_method_hasTagCompound_42.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).hasTagCompound(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_hasTagCompound_42); + + BaseData reflect_ItemStack_method_getTagCompound_43 = new ModData(); + reflect_ItemStack_method_getTagCompound_43.set("methodName", "getTagCompound"); + reflect_ItemStack_method_getTagCompound_43.set("returnType", "ItemStack"); + reflect_ItemStack_method_getTagCompound_43.set("static", false); + reflect_ItemStack_method_getTagCompound_43.set("argnames", new String[] {}); + reflect_ItemStack_method_getTagCompound_43.set("argtypes", new String[] {}); + reflect_ItemStack_method_getTagCompound_43.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (NBTTagCompound) ((ItemStack) params.getReflective("_self")).getTagCompound(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getTagCompound_43); + + BaseData reflect_ItemStack_method_getSubCompound_44 = new ModData(); + reflect_ItemStack_method_getSubCompound_44.set("methodName", "getSubCompound"); + reflect_ItemStack_method_getSubCompound_44.set("returnType", "ItemStack"); + reflect_ItemStack_method_getSubCompound_44.set("static", false); + reflect_ItemStack_method_getSubCompound_44.set("argnames", new String[] { "key", "create" }); + reflect_ItemStack_method_getSubCompound_44.set("argtypes", new String[] { "String", "boolean" }); + reflect_ItemStack_method_getSubCompound_44.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (NBTTagCompound) ((ItemStack) params.getReflective("_self")) + .getSubCompound((String) params.getString("key"), (boolean) params.getBoolean("create")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getSubCompound_44); + + BaseData reflect_ItemStack_method_getEnchantmentTagList_45 = new ModData(); + reflect_ItemStack_method_getEnchantmentTagList_45.set("methodName", "getEnchantmentTagList"); + reflect_ItemStack_method_getEnchantmentTagList_45.set("returnType", "ItemStack"); + reflect_ItemStack_method_getEnchantmentTagList_45.set("static", false); + reflect_ItemStack_method_getEnchantmentTagList_45.set("argnames", new String[] {}); + reflect_ItemStack_method_getEnchantmentTagList_45.set("argtypes", new String[] {}); + reflect_ItemStack_method_getEnchantmentTagList_45.setCallbackReflectiveWithDataArg("exec", + (BaseData params) -> { + try { + return (NBTTagList) ((ItemStack) params.getReflective("_self")).getEnchantmentTagList(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getEnchantmentTagList_45); + + BaseData reflect_ItemStack_method_setTagCompound_46 = new ModData(); + reflect_ItemStack_method_setTagCompound_46.set("methodName", "setTagCompound"); + reflect_ItemStack_method_setTagCompound_46.set("returnType", "ItemStack"); + reflect_ItemStack_method_setTagCompound_46.set("static", false); + reflect_ItemStack_method_setTagCompound_46.set("argnames", new String[] { "nbt" }); + reflect_ItemStack_method_setTagCompound_46.set("argtypes", new String[] { "NBTTagCompound" }); + reflect_ItemStack_method_setTagCompound_46.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")) + .setTagCompound((NBTTagCompound) params.getReflective("nbt")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setTagCompound_46); + + BaseData reflect_ItemStack_method_getDisplayName_47 = new ModData(); + reflect_ItemStack_method_getDisplayName_47.set("methodName", "getDisplayName"); + reflect_ItemStack_method_getDisplayName_47.set("returnType", "ItemStack"); + reflect_ItemStack_method_getDisplayName_47.set("static", false); + reflect_ItemStack_method_getDisplayName_47.set("argnames", new String[] {}); + reflect_ItemStack_method_getDisplayName_47.set("argtypes", new String[] {}); + reflect_ItemStack_method_getDisplayName_47.setCallbackStringWithDataArg("exec", (BaseData params) -> { + try { + return (String) ((ItemStack) params.getReflective("_self")).getDisplayName(); + } catch (Exception _exception_reflect_) { + return ""; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getDisplayName_47); + + BaseData reflect_ItemStack_method_setStackDisplayName_48 = new ModData(); + reflect_ItemStack_method_setStackDisplayName_48.set("methodName", "setStackDisplayName"); + reflect_ItemStack_method_setStackDisplayName_48.set("returnType", "ItemStack"); + reflect_ItemStack_method_setStackDisplayName_48.set("static", false); + reflect_ItemStack_method_setStackDisplayName_48.set("argnames", new String[] { "displayName" }); + reflect_ItemStack_method_setStackDisplayName_48.set("argtypes", new String[] { "String" }); + reflect_ItemStack_method_setStackDisplayName_48.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemStack) ((ItemStack) params.getReflective("_self")) + .setStackDisplayName((String) params.getString("displayName")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setStackDisplayName_48); + + BaseData reflect_ItemStack_method_setLore_49 = new ModData(); + reflect_ItemStack_method_setLore_49.set("methodName", "setLore"); + reflect_ItemStack_method_setLore_49.set("returnType", "ItemStack"); + reflect_ItemStack_method_setLore_49.set("static", false); + reflect_ItemStack_method_setLore_49.set("argnames", new String[] { "loreIn" }); + reflect_ItemStack_method_setLore_49.set("argtypes", new String[] { "String[]" }); + reflect_ItemStack_method_setLore_49.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).setLore((String[]) params.getReflective("loreIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setLore_49); + + BaseData reflect_ItemStack_method_getLore_50 = new ModData(); + reflect_ItemStack_method_getLore_50.set("methodName", "getLore"); + reflect_ItemStack_method_getLore_50.set("returnType", "ItemStack"); + reflect_ItemStack_method_getLore_50.set("static", false); + reflect_ItemStack_method_getLore_50.set("argnames", new String[] {}); + reflect_ItemStack_method_getLore_50.set("argtypes", new String[] {}); + reflect_ItemStack_method_getLore_50.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (String[]) ((ItemStack) params.getReflective("_self")).getLore(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getLore_50); + + BaseData reflect_ItemStack_method_clearCustomName_51 = new ModData(); + reflect_ItemStack_method_clearCustomName_51.set("methodName", "clearCustomName"); + reflect_ItemStack_method_clearCustomName_51.set("returnType", "ItemStack"); + reflect_ItemStack_method_clearCustomName_51.set("static", false); + reflect_ItemStack_method_clearCustomName_51.set("argnames", new String[] {}); + reflect_ItemStack_method_clearCustomName_51.set("argtypes", new String[] {}); + reflect_ItemStack_method_clearCustomName_51.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).clearCustomName(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_clearCustomName_51); + + BaseData reflect_ItemStack_method_hasDisplayName_52 = new ModData(); + reflect_ItemStack_method_hasDisplayName_52.set("methodName", "hasDisplayName"); + reflect_ItemStack_method_hasDisplayName_52.set("returnType", "ItemStack"); + reflect_ItemStack_method_hasDisplayName_52.set("static", false); + reflect_ItemStack_method_hasDisplayName_52.set("argnames", new String[] {}); + reflect_ItemStack_method_hasDisplayName_52.set("argtypes", new String[] {}); + reflect_ItemStack_method_hasDisplayName_52.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).hasDisplayName(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_hasDisplayName_52); + + BaseData reflect_ItemStack_method_hasEffect_53 = new ModData(); + reflect_ItemStack_method_hasEffect_53.set("methodName", "hasEffect"); + reflect_ItemStack_method_hasEffect_53.set("returnType", "ItemStack"); + reflect_ItemStack_method_hasEffect_53.set("static", false); + reflect_ItemStack_method_hasEffect_53.set("argnames", new String[] {}); + reflect_ItemStack_method_hasEffect_53.set("argtypes", new String[] {}); + reflect_ItemStack_method_hasEffect_53.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).hasEffect(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_hasEffect_53); + + BaseData reflect_ItemStack_method_getRarity_54 = new ModData(); + reflect_ItemStack_method_getRarity_54.set("methodName", "getRarity"); + reflect_ItemStack_method_getRarity_54.set("returnType", "ItemStack"); + reflect_ItemStack_method_getRarity_54.set("static", false); + reflect_ItemStack_method_getRarity_54.set("argnames", new String[] {}); + reflect_ItemStack_method_getRarity_54.set("argtypes", new String[] {}); + reflect_ItemStack_method_getRarity_54.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (EnumRarity) ((ItemStack) params.getReflective("_self")).getRarity(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getRarity_54); + + BaseData reflect_ItemStack_method_isItemEnchantable_55 = new ModData(); + reflect_ItemStack_method_isItemEnchantable_55.set("methodName", "isItemEnchantable"); + reflect_ItemStack_method_isItemEnchantable_55.set("returnType", "ItemStack"); + reflect_ItemStack_method_isItemEnchantable_55.set("static", false); + reflect_ItemStack_method_isItemEnchantable_55.set("argnames", new String[] {}); + reflect_ItemStack_method_isItemEnchantable_55.set("argtypes", new String[] {}); + reflect_ItemStack_method_isItemEnchantable_55.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isItemEnchantable(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isItemEnchantable_55); + + BaseData reflect_ItemStack_method_addEnchantment_56 = new ModData(); + reflect_ItemStack_method_addEnchantment_56.set("methodName", "addEnchantment"); + reflect_ItemStack_method_addEnchantment_56.set("returnType", "ItemStack"); + reflect_ItemStack_method_addEnchantment_56.set("static", false); + reflect_ItemStack_method_addEnchantment_56.set("argnames", new String[] { "ench", "level" }); + reflect_ItemStack_method_addEnchantment_56.set("argtypes", new String[] { "Enchantment", "int" }); + reflect_ItemStack_method_addEnchantment_56.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).addEnchantment((Enchantment) params.getReflective("ench"), + (int) params.getInt("level")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_addEnchantment_56); + + BaseData reflect_ItemStack_method_isItemEnchanted_57 = new ModData(); + reflect_ItemStack_method_isItemEnchanted_57.set("methodName", "isItemEnchanted"); + reflect_ItemStack_method_isItemEnchanted_57.set("returnType", "ItemStack"); + reflect_ItemStack_method_isItemEnchanted_57.set("static", false); + reflect_ItemStack_method_isItemEnchanted_57.set("argnames", new String[] {}); + reflect_ItemStack_method_isItemEnchanted_57.set("argtypes", new String[] {}); + reflect_ItemStack_method_isItemEnchanted_57.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isItemEnchanted(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isItemEnchanted_57); + + BaseData reflect_ItemStack_method_setTagInfo_58 = new ModData(); + reflect_ItemStack_method_setTagInfo_58.set("methodName", "setTagInfo"); + reflect_ItemStack_method_setTagInfo_58.set("returnType", "ItemStack"); + reflect_ItemStack_method_setTagInfo_58.set("static", false); + reflect_ItemStack_method_setTagInfo_58.set("argnames", new String[] { "key", "value" }); + reflect_ItemStack_method_setTagInfo_58.set("argtypes", new String[] { "String", "NBTBase" }); + reflect_ItemStack_method_setTagInfo_58.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).setTagInfo((String) params.getString("key"), + (NBTBase) params.getReflective("value")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setTagInfo_58); + + BaseData reflect_ItemStack_method_canEditBlocks_59 = new ModData(); + reflect_ItemStack_method_canEditBlocks_59.set("methodName", "canEditBlocks"); + reflect_ItemStack_method_canEditBlocks_59.set("returnType", "ItemStack"); + reflect_ItemStack_method_canEditBlocks_59.set("static", false); + reflect_ItemStack_method_canEditBlocks_59.set("argnames", new String[] {}); + reflect_ItemStack_method_canEditBlocks_59.set("argtypes", new String[] {}); + reflect_ItemStack_method_canEditBlocks_59.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).canEditBlocks(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_canEditBlocks_59); + + BaseData reflect_ItemStack_method_isOnItemFrame_60 = new ModData(); + reflect_ItemStack_method_isOnItemFrame_60.set("methodName", "isOnItemFrame"); + reflect_ItemStack_method_isOnItemFrame_60.set("returnType", "ItemStack"); + reflect_ItemStack_method_isOnItemFrame_60.set("static", false); + reflect_ItemStack_method_isOnItemFrame_60.set("argnames", new String[] {}); + reflect_ItemStack_method_isOnItemFrame_60.set("argtypes", new String[] {}); + reflect_ItemStack_method_isOnItemFrame_60.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")).isOnItemFrame(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_isOnItemFrame_60); + + BaseData reflect_ItemStack_method_setItemFrame_61 = new ModData(); + reflect_ItemStack_method_setItemFrame_61.set("methodName", "setItemFrame"); + reflect_ItemStack_method_setItemFrame_61.set("returnType", "ItemStack"); + reflect_ItemStack_method_setItemFrame_61.set("static", false); + reflect_ItemStack_method_setItemFrame_61.set("argnames", new String[] { "frame" }); + reflect_ItemStack_method_setItemFrame_61.set("argtypes", new String[] { "EntityItemFrame" }); + reflect_ItemStack_method_setItemFrame_61.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")) + .setItemFrame((EntityItemFrame) params.getReflective("frame")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setItemFrame_61); + + BaseData reflect_ItemStack_method_getItemFrame_62 = new ModData(); + reflect_ItemStack_method_getItemFrame_62.set("methodName", "getItemFrame"); + reflect_ItemStack_method_getItemFrame_62.set("returnType", "ItemStack"); + reflect_ItemStack_method_getItemFrame_62.set("static", false); + reflect_ItemStack_method_getItemFrame_62.set("argnames", new String[] {}); + reflect_ItemStack_method_getItemFrame_62.set("argtypes", new String[] {}); + reflect_ItemStack_method_getItemFrame_62.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (EntityItemFrame) ((ItemStack) params.getReflective("_self")).getItemFrame(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getItemFrame_62); + + BaseData reflect_ItemStack_method_getRepairCost_63 = new ModData(); + reflect_ItemStack_method_getRepairCost_63.set("methodName", "getRepairCost"); + reflect_ItemStack_method_getRepairCost_63.set("returnType", "ItemStack"); + reflect_ItemStack_method_getRepairCost_63.set("static", false); + reflect_ItemStack_method_getRepairCost_63.set("argnames", new String[] {}); + reflect_ItemStack_method_getRepairCost_63.set("argtypes", new String[] {}); + reflect_ItemStack_method_getRepairCost_63.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((ItemStack) params.getReflective("_self")).getRepairCost(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getRepairCost_63); + + BaseData reflect_ItemStack_method_setRepairCost_64 = new ModData(); + reflect_ItemStack_method_setRepairCost_64.set("methodName", "setRepairCost"); + reflect_ItemStack_method_setRepairCost_64.set("returnType", "ItemStack"); + reflect_ItemStack_method_setRepairCost_64.set("static", false); + reflect_ItemStack_method_setRepairCost_64.set("argnames", new String[] { "cost" }); + reflect_ItemStack_method_setRepairCost_64.set("argtypes", new String[] { "int" }); + reflect_ItemStack_method_setRepairCost_64.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).setRepairCost((int) params.getInt("cost")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setRepairCost_64); + + BaseData reflect_ItemStack_method_setItem_65 = new ModData(); + reflect_ItemStack_method_setItem_65.set("methodName", "setItem"); + reflect_ItemStack_method_setItem_65.set("returnType", "ItemStack"); + reflect_ItemStack_method_setItem_65.set("static", false); + reflect_ItemStack_method_setItem_65.set("argnames", new String[] { "newItem" }); + reflect_ItemStack_method_setItem_65.set("argtypes", new String[] { "Item" }); + reflect_ItemStack_method_setItem_65.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((ItemStack) params.getReflective("_self")).setItem((Item) params.getReflective("newItem")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_setItem_65); + + BaseData reflect_ItemStack_method_getChatComponent_66 = new ModData(); + reflect_ItemStack_method_getChatComponent_66.set("methodName", "getChatComponent"); + reflect_ItemStack_method_getChatComponent_66.set("returnType", "ItemStack"); + reflect_ItemStack_method_getChatComponent_66.set("static", false); + reflect_ItemStack_method_getChatComponent_66.set("argnames", new String[] {}); + reflect_ItemStack_method_getChatComponent_66.set("argtypes", new String[] {}); + reflect_ItemStack_method_getChatComponent_66.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (IChatComponent) ((ItemStack) params.getReflective("_self")).getChatComponent(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_getChatComponent_66); + + BaseData reflect_ItemStack_method_canDestroy_67 = new ModData(); + reflect_ItemStack_method_canDestroy_67.set("methodName", "canDestroy"); + reflect_ItemStack_method_canDestroy_67.set("returnType", "ItemStack"); + reflect_ItemStack_method_canDestroy_67.set("static", false); + reflect_ItemStack_method_canDestroy_67.set("argnames", new String[] { "blockIn" }); + reflect_ItemStack_method_canDestroy_67.set("argtypes", new String[] { "Block" }); + reflect_ItemStack_method_canDestroy_67.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")) + .canDestroy((Block) params.getReflective("blockIn")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_canDestroy_67); + + BaseData reflect_ItemStack_method_canPlaceOn_68 = new ModData(); + reflect_ItemStack_method_canPlaceOn_68.set("methodName", "canPlaceOn"); + reflect_ItemStack_method_canPlaceOn_68.set("returnType", "ItemStack"); + reflect_ItemStack_method_canPlaceOn_68.set("static", false); + reflect_ItemStack_method_canPlaceOn_68.set("argnames", new String[] { "blockIn" }); + reflect_ItemStack_method_canPlaceOn_68.set("argtypes", new String[] { "Block" }); + reflect_ItemStack_method_canPlaceOn_68.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((ItemStack) params.getReflective("_self")) + .canPlaceOn((Block) params.getReflective("blockIn")); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_ItemStack_methods.add(reflect_ItemStack_method_canPlaceOn_68); + + BaseData[] reflect_ItemStack_methods_arr = new BaseData[reflect_ItemStack_methods.size()]; + for (int i = 0; i < reflect_ItemStack_methods_arr.length; i++) { + reflect_ItemStack_methods_arr[i] = reflect_ItemStack_methods.get(i); + } + + reflect_ItemStack.set("constructors", reflect_ItemStack_constructors_arr); + reflect_ItemStack.set("methods", reflect_ItemStack_methods_arr); + reflect_ItemStack.set("className", "ItemStack"); + reflect_ItemStack.set("classId", "net.minecraft.item.ItemStack"); + reflect_ItemStack.set("class", ItemStack.class); + reflectProfiles.add(reflect_ItemStack); + + // CLASSDEF FOR Minecraft + BaseData reflect_Minecraft = new ModData(); + + ArrayList reflect_Minecraft_constructors = new ArrayList(); + + BaseData reflect_Minecraft_constructor_Minecraft_0 = new ModData(); + reflect_Minecraft_constructor_Minecraft_0.set("returnType", "Minecraft"); + reflect_Minecraft_constructor_Minecraft_0.set("argnames", new String[] { "gameConfig" }); + reflect_Minecraft_constructor_Minecraft_0.set("argtypes", new String[] { "GameConfiguration" }); + reflect_Minecraft_constructor_Minecraft_0.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + return new Minecraft((GameConfiguration) params.getReflective("gameConfig")); + }); + + reflect_Minecraft_constructors.add(reflect_Minecraft_constructor_Minecraft_0); + + BaseData[] reflect_Minecraft_constructors_arr = new BaseData[reflect_Minecraft_constructors.size()]; + for (int i = 0; i < reflect_Minecraft_constructors_arr.length; i++) { + reflect_Minecraft_constructors_arr[i] = reflect_Minecraft_constructors.get(i); + } + + ArrayList reflect_Minecraft_methods = new ArrayList(); + + BaseData reflect_Minecraft_method_run_0 = new ModData(); + reflect_Minecraft_method_run_0.set("methodName", "run"); + reflect_Minecraft_method_run_0.set("returnType", "Minecraft"); + reflect_Minecraft_method_run_0.set("static", false); + reflect_Minecraft_method_run_0.set("argnames", new String[] {}); + reflect_Minecraft_method_run_0.set("argtypes", new String[] {}); + reflect_Minecraft_method_run_0.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).run(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_run_0); + + BaseData reflect_Minecraft_method_getVersion_1 = new ModData(); + reflect_Minecraft_method_getVersion_1.set("methodName", "getVersion"); + reflect_Minecraft_method_getVersion_1.set("returnType", "Minecraft"); + reflect_Minecraft_method_getVersion_1.set("static", false); + reflect_Minecraft_method_getVersion_1.set("argnames", new String[] {}); + reflect_Minecraft_method_getVersion_1.set("argtypes", new String[] {}); + reflect_Minecraft_method_getVersion_1.setCallbackStringWithDataArg("exec", (BaseData params) -> { + try { + return (String) ((Minecraft) params.getReflective("_self")).getVersion(); + } catch (Exception _exception_reflect_) { + return ""; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getVersion_1); + + BaseData reflect_Minecraft_method_crashed_2 = new ModData(); + reflect_Minecraft_method_crashed_2.set("methodName", "crashed"); + reflect_Minecraft_method_crashed_2.set("returnType", "Minecraft"); + reflect_Minecraft_method_crashed_2.set("static", false); + reflect_Minecraft_method_crashed_2.set("argnames", new String[] { "crash" }); + reflect_Minecraft_method_crashed_2.set("argtypes", new String[] { "CrashReport" }); + reflect_Minecraft_method_crashed_2.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).crashed((CrashReport) params.getReflective("crash")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_crashed_2); + + BaseData reflect_Minecraft_method_displayCrashReport_3 = new ModData(); + reflect_Minecraft_method_displayCrashReport_3.set("methodName", "displayCrashReport"); + reflect_Minecraft_method_displayCrashReport_3.set("returnType", "Minecraft"); + reflect_Minecraft_method_displayCrashReport_3.set("static", false); + reflect_Minecraft_method_displayCrashReport_3.set("argnames", new String[] { "crashReportIn" }); + reflect_Minecraft_method_displayCrashReport_3.set("argtypes", new String[] { "CrashReport" }); + reflect_Minecraft_method_displayCrashReport_3.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .displayCrashReport((CrashReport) params.getReflective("crashReportIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_displayCrashReport_3); + + BaseData reflect_Minecraft_method_isUnicode_4 = new ModData(); + reflect_Minecraft_method_isUnicode_4.set("methodName", "isUnicode"); + reflect_Minecraft_method_isUnicode_4.set("returnType", "Minecraft"); + reflect_Minecraft_method_isUnicode_4.set("static", false); + reflect_Minecraft_method_isUnicode_4.set("argnames", new String[] {}); + reflect_Minecraft_method_isUnicode_4.set("argtypes", new String[] {}); + reflect_Minecraft_method_isUnicode_4.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isUnicode(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isUnicode_4); + + BaseData reflect_Minecraft_method_refreshResources_5 = new ModData(); + reflect_Minecraft_method_refreshResources_5.set("methodName", "refreshResources"); + reflect_Minecraft_method_refreshResources_5.set("returnType", "Minecraft"); + reflect_Minecraft_method_refreshResources_5.set("static", false); + reflect_Minecraft_method_refreshResources_5.set("argnames", new String[] {}); + reflect_Minecraft_method_refreshResources_5.set("argtypes", new String[] {}); + reflect_Minecraft_method_refreshResources_5.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).refreshResources(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_refreshResources_5); + + BaseData reflect_Minecraft_method_displayGuiScreen_6 = new ModData(); + reflect_Minecraft_method_displayGuiScreen_6.set("methodName", "displayGuiScreen"); + reflect_Minecraft_method_displayGuiScreen_6.set("returnType", "Minecraft"); + reflect_Minecraft_method_displayGuiScreen_6.set("static", false); + reflect_Minecraft_method_displayGuiScreen_6.set("argnames", new String[] { "guiScreenIn" }); + reflect_Minecraft_method_displayGuiScreen_6.set("argtypes", new String[] { "GuiScreen" }); + reflect_Minecraft_method_displayGuiScreen_6.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .displayGuiScreen((GuiScreen) params.getReflective("guiScreenIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_displayGuiScreen_6); + + BaseData reflect_Minecraft_method_shutdownIntegratedServer_7 = new ModData(); + reflect_Minecraft_method_shutdownIntegratedServer_7.set("methodName", "shutdownIntegratedServer"); + reflect_Minecraft_method_shutdownIntegratedServer_7.set("returnType", "Minecraft"); + reflect_Minecraft_method_shutdownIntegratedServer_7.set("static", false); + reflect_Minecraft_method_shutdownIntegratedServer_7.set("argnames", new String[] { "cont" }); + reflect_Minecraft_method_shutdownIntegratedServer_7.set("argtypes", new String[] { "GuiScreen" }); + reflect_Minecraft_method_shutdownIntegratedServer_7.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .shutdownIntegratedServer((GuiScreen) params.getReflective("cont")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_shutdownIntegratedServer_7); + + BaseData reflect_Minecraft_method_checkGLError_8 = new ModData(); + reflect_Minecraft_method_checkGLError_8.set("methodName", "checkGLError"); + reflect_Minecraft_method_checkGLError_8.set("returnType", "Minecraft"); + reflect_Minecraft_method_checkGLError_8.set("static", false); + reflect_Minecraft_method_checkGLError_8.set("argnames", new String[] { "message" }); + reflect_Minecraft_method_checkGLError_8.set("argtypes", new String[] { "String" }); + reflect_Minecraft_method_checkGLError_8.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).checkGLError((String) params.getString("message")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_checkGLError_8); + + BaseData reflect_Minecraft_method_shutdownMinecraftApplet_9 = new ModData(); + reflect_Minecraft_method_shutdownMinecraftApplet_9.set("methodName", "shutdownMinecraftApplet"); + reflect_Minecraft_method_shutdownMinecraftApplet_9.set("returnType", "Minecraft"); + reflect_Minecraft_method_shutdownMinecraftApplet_9.set("static", false); + reflect_Minecraft_method_shutdownMinecraftApplet_9.set("argnames", new String[] {}); + reflect_Minecraft_method_shutdownMinecraftApplet_9.set("argtypes", new String[] {}); + reflect_Minecraft_method_shutdownMinecraftApplet_9.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).shutdownMinecraftApplet(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_shutdownMinecraftApplet_9); + + BaseData reflect_Minecraft_method_updateDisplay_10 = new ModData(); + reflect_Minecraft_method_updateDisplay_10.set("methodName", "updateDisplay"); + reflect_Minecraft_method_updateDisplay_10.set("returnType", "Minecraft"); + reflect_Minecraft_method_updateDisplay_10.set("static", false); + reflect_Minecraft_method_updateDisplay_10.set("argnames", new String[] {}); + reflect_Minecraft_method_updateDisplay_10.set("argtypes", new String[] {}); + reflect_Minecraft_method_updateDisplay_10.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).updateDisplay(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_updateDisplay_10); + + BaseData reflect_Minecraft_method_getLimitFramerate_11 = new ModData(); + reflect_Minecraft_method_getLimitFramerate_11.set("methodName", "getLimitFramerate"); + reflect_Minecraft_method_getLimitFramerate_11.set("returnType", "Minecraft"); + reflect_Minecraft_method_getLimitFramerate_11.set("static", false); + reflect_Minecraft_method_getLimitFramerate_11.set("argnames", new String[] {}); + reflect_Minecraft_method_getLimitFramerate_11.set("argtypes", new String[] {}); + reflect_Minecraft_method_getLimitFramerate_11.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) ((Minecraft) params.getReflective("_self")).getLimitFramerate(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getLimitFramerate_11); + + BaseData reflect_Minecraft_method_isFramerateLimitBelowMax_12 = new ModData(); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.set("methodName", "isFramerateLimitBelowMax"); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.set("returnType", "Minecraft"); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.set("static", false); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.set("argnames", new String[] {}); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.set("argtypes", new String[] {}); + reflect_Minecraft_method_isFramerateLimitBelowMax_12.setCallbackBooleanWithDataArg("exec", + (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isFramerateLimitBelowMax(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isFramerateLimitBelowMax_12); + + BaseData reflect_Minecraft_method_shutdown_13 = new ModData(); + reflect_Minecraft_method_shutdown_13.set("methodName", "shutdown"); + reflect_Minecraft_method_shutdown_13.set("returnType", "Minecraft"); + reflect_Minecraft_method_shutdown_13.set("static", false); + reflect_Minecraft_method_shutdown_13.set("argnames", new String[] {}); + reflect_Minecraft_method_shutdown_13.set("argtypes", new String[] {}); + reflect_Minecraft_method_shutdown_13.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).shutdown(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_shutdown_13); + + BaseData reflect_Minecraft_method_setIngameFocus_14 = new ModData(); + reflect_Minecraft_method_setIngameFocus_14.set("methodName", "setIngameFocus"); + reflect_Minecraft_method_setIngameFocus_14.set("returnType", "Minecraft"); + reflect_Minecraft_method_setIngameFocus_14.set("static", false); + reflect_Minecraft_method_setIngameFocus_14.set("argnames", new String[] {}); + reflect_Minecraft_method_setIngameFocus_14.set("argtypes", new String[] {}); + reflect_Minecraft_method_setIngameFocus_14.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).setIngameFocus(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_setIngameFocus_14); + + BaseData reflect_Minecraft_method_setIngameNotInFocus_15 = new ModData(); + reflect_Minecraft_method_setIngameNotInFocus_15.set("methodName", "setIngameNotInFocus"); + reflect_Minecraft_method_setIngameNotInFocus_15.set("returnType", "Minecraft"); + reflect_Minecraft_method_setIngameNotInFocus_15.set("static", false); + reflect_Minecraft_method_setIngameNotInFocus_15.set("argnames", new String[] {}); + reflect_Minecraft_method_setIngameNotInFocus_15.set("argtypes", new String[] {}); + reflect_Minecraft_method_setIngameNotInFocus_15.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).setIngameNotInFocus(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_setIngameNotInFocus_15); + + BaseData reflect_Minecraft_method_displayInGameMenu_16 = new ModData(); + reflect_Minecraft_method_displayInGameMenu_16.set("methodName", "displayInGameMenu"); + reflect_Minecraft_method_displayInGameMenu_16.set("returnType", "Minecraft"); + reflect_Minecraft_method_displayInGameMenu_16.set("static", false); + reflect_Minecraft_method_displayInGameMenu_16.set("argnames", new String[] {}); + reflect_Minecraft_method_displayInGameMenu_16.set("argtypes", new String[] {}); + reflect_Minecraft_method_displayInGameMenu_16.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).displayInGameMenu(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_displayInGameMenu_16); + + BaseData reflect_Minecraft_method_clickMouse_17 = new ModData(); + reflect_Minecraft_method_clickMouse_17.set("methodName", "clickMouse"); + reflect_Minecraft_method_clickMouse_17.set("returnType", "Minecraft"); + reflect_Minecraft_method_clickMouse_17.set("static", false); + reflect_Minecraft_method_clickMouse_17.set("argnames", new String[] {}); + reflect_Minecraft_method_clickMouse_17.set("argtypes", new String[] {}); + reflect_Minecraft_method_clickMouse_17.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).clickMouse(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_clickMouse_17); + + BaseData reflect_Minecraft_method_rightClickMouse_18 = new ModData(); + reflect_Minecraft_method_rightClickMouse_18.set("methodName", "rightClickMouse"); + reflect_Minecraft_method_rightClickMouse_18.set("returnType", "Minecraft"); + reflect_Minecraft_method_rightClickMouse_18.set("static", false); + reflect_Minecraft_method_rightClickMouse_18.set("argnames", new String[] {}); + reflect_Minecraft_method_rightClickMouse_18.set("argtypes", new String[] {}); + reflect_Minecraft_method_rightClickMouse_18.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).rightClickMouse(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_rightClickMouse_18); + + BaseData reflect_Minecraft_method_toggleFullscreen_19 = new ModData(); + reflect_Minecraft_method_toggleFullscreen_19.set("methodName", "toggleFullscreen"); + reflect_Minecraft_method_toggleFullscreen_19.set("returnType", "Minecraft"); + reflect_Minecraft_method_toggleFullscreen_19.set("static", false); + reflect_Minecraft_method_toggleFullscreen_19.set("argnames", new String[] {}); + reflect_Minecraft_method_toggleFullscreen_19.set("argtypes", new String[] {}); + reflect_Minecraft_method_toggleFullscreen_19.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).toggleFullscreen(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_toggleFullscreen_19); + + BaseData reflect_Minecraft_method_func_181535_r_20 = new ModData(); + reflect_Minecraft_method_func_181535_r_20.set("methodName", "func_181535_r"); + reflect_Minecraft_method_func_181535_r_20.set("returnType", "Minecraft"); + reflect_Minecraft_method_func_181535_r_20.set("static", false); + reflect_Minecraft_method_func_181535_r_20.set("argnames", new String[] {}); + reflect_Minecraft_method_func_181535_r_20.set("argtypes", new String[] {}); + reflect_Minecraft_method_func_181535_r_20.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (MusicTicker) ((Minecraft) params.getReflective("_self")).func_181535_r(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_func_181535_r_20); + + BaseData reflect_Minecraft_method_runTick_21 = new ModData(); + reflect_Minecraft_method_runTick_21.set("methodName", "runTick"); + reflect_Minecraft_method_runTick_21.set("returnType", "Minecraft"); + reflect_Minecraft_method_runTick_21.set("static", false); + reflect_Minecraft_method_runTick_21.set("argnames", new String[] {}); + reflect_Minecraft_method_runTick_21.set("argtypes", new String[] {}); + reflect_Minecraft_method_runTick_21.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).runTick(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_runTick_21); + + BaseData reflect_Minecraft_method_launchIntegratedServer_22 = new ModData(); + reflect_Minecraft_method_launchIntegratedServer_22.set("methodName", "launchIntegratedServer"); + reflect_Minecraft_method_launchIntegratedServer_22.set("returnType", "Minecraft"); + reflect_Minecraft_method_launchIntegratedServer_22.set("static", false); + reflect_Minecraft_method_launchIntegratedServer_22.set("argnames", + new String[] { "folderName", "worldName", "worldSettingsIn" }); + reflect_Minecraft_method_launchIntegratedServer_22.set("argtypes", + new String[] { "String", "String", "WorldSettings" }); + reflect_Minecraft_method_launchIntegratedServer_22.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).launchIntegratedServer( + (String) params.getString("folderName"), (String) params.getString("worldName"), + (WorldSettings) params.getReflective("worldSettingsIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_launchIntegratedServer_22); + + BaseData reflect_Minecraft_method_loadWorld_23 = new ModData(); + reflect_Minecraft_method_loadWorld_23.set("methodName", "loadWorld"); + reflect_Minecraft_method_loadWorld_23.set("returnType", "Minecraft"); + reflect_Minecraft_method_loadWorld_23.set("static", false); + reflect_Minecraft_method_loadWorld_23.set("argnames", new String[] { "worldClientIn" }); + reflect_Minecraft_method_loadWorld_23.set("argtypes", new String[] { "WorldClient" }); + reflect_Minecraft_method_loadWorld_23.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .loadWorld((WorldClient) params.getReflective("worldClientIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_loadWorld_23); + + BaseData reflect_Minecraft_method_loadWorld_24 = new ModData(); + reflect_Minecraft_method_loadWorld_24.set("methodName", "loadWorld"); + reflect_Minecraft_method_loadWorld_24.set("returnType", "Minecraft"); + reflect_Minecraft_method_loadWorld_24.set("static", false); + reflect_Minecraft_method_loadWorld_24.set("argnames", new String[] { "worldClientIn", "loadingMessage" }); + reflect_Minecraft_method_loadWorld_24.set("argtypes", new String[] { "WorldClient", "String" }); + reflect_Minecraft_method_loadWorld_24.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).loadWorld( + (WorldClient) params.getReflective("worldClientIn"), + (String) params.getString("loadingMessage")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_loadWorld_24); + + BaseData reflect_Minecraft_method_setDimensionAndSpawnPlayer_25 = new ModData(); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.set("methodName", "setDimensionAndSpawnPlayer"); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.set("returnType", "Minecraft"); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.set("static", false); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.set("argnames", new String[] { "dimension" }); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.set("argtypes", new String[] { "int" }); + reflect_Minecraft_method_setDimensionAndSpawnPlayer_25.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .setDimensionAndSpawnPlayer((int) params.getInt("dimension")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_setDimensionAndSpawnPlayer_25); + + BaseData reflect_Minecraft_method_isDemo_26 = new ModData(); + reflect_Minecraft_method_isDemo_26.set("methodName", "isDemo"); + reflect_Minecraft_method_isDemo_26.set("returnType", "Minecraft"); + reflect_Minecraft_method_isDemo_26.set("static", false); + reflect_Minecraft_method_isDemo_26.set("argnames", new String[] {}); + reflect_Minecraft_method_isDemo_26.set("argtypes", new String[] {}); + reflect_Minecraft_method_isDemo_26.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isDemo(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isDemo_26); + + BaseData reflect_Minecraft_method_getNetHandler_27 = new ModData(); + reflect_Minecraft_method_getNetHandler_27.set("methodName", "getNetHandler"); + reflect_Minecraft_method_getNetHandler_27.set("returnType", "Minecraft"); + reflect_Minecraft_method_getNetHandler_27.set("static", false); + reflect_Minecraft_method_getNetHandler_27.set("argnames", new String[] {}); + reflect_Minecraft_method_getNetHandler_27.set("argtypes", new String[] {}); + reflect_Minecraft_method_getNetHandler_27.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (NetHandlerPlayClient) ((Minecraft) params.getReflective("_self")).getNetHandler(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getNetHandler_27); + + BaseData reflect_Minecraft_method_isGuiEnabled_28 = new ModData(); + reflect_Minecraft_method_isGuiEnabled_28.set("methodName", "isGuiEnabled"); + reflect_Minecraft_method_isGuiEnabled_28.set("returnType", "Minecraft"); + reflect_Minecraft_method_isGuiEnabled_28.set("static", true); + reflect_Minecraft_method_isGuiEnabled_28.set("argnames", new String[] {}); + reflect_Minecraft_method_isGuiEnabled_28.set("argtypes", new String[] {}); + reflect_Minecraft_method_isGuiEnabled_28.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) Minecraft.isGuiEnabled(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isGuiEnabled_28); + + BaseData reflect_Minecraft_method_isFancyGraphicsEnabled_29 = new ModData(); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.set("methodName", "isFancyGraphicsEnabled"); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.set("returnType", "Minecraft"); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.set("static", true); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.set("argnames", new String[] {}); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.set("argtypes", new String[] {}); + reflect_Minecraft_method_isFancyGraphicsEnabled_29.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) Minecraft.isFancyGraphicsEnabled(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isFancyGraphicsEnabled_29); + + BaseData reflect_Minecraft_method_isAmbientOcclusionEnabled_30 = new ModData(); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.set("methodName", "isAmbientOcclusionEnabled"); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.set("returnType", "Minecraft"); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.set("static", true); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.set("argnames", new String[] {}); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.set("argtypes", new String[] {}); + reflect_Minecraft_method_isAmbientOcclusionEnabled_30.setCallbackBooleanWithDataArg("exec", + (BaseData params) -> { + try { + return (boolean) Minecraft.isAmbientOcclusionEnabled(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isAmbientOcclusionEnabled_30); + + BaseData reflect_Minecraft_method_middleClickMouse_31 = new ModData(); + reflect_Minecraft_method_middleClickMouse_31.set("methodName", "middleClickMouse"); + reflect_Minecraft_method_middleClickMouse_31.set("returnType", "Minecraft"); + reflect_Minecraft_method_middleClickMouse_31.set("static", false); + reflect_Minecraft_method_middleClickMouse_31.set("argnames", new String[] {}); + reflect_Minecraft_method_middleClickMouse_31.set("argtypes", new String[] {}); + reflect_Minecraft_method_middleClickMouse_31.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).middleClickMouse(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_middleClickMouse_31); + + BaseData reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32 = new ModData(); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.set("methodName", + "addGraphicsAndWorldToCrashReport"); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.set("returnType", "Minecraft"); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.set("static", false); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.set("argnames", new String[] { "theCrash" }); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.set("argtypes", new String[] { "CrashReport" }); + reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32.setCallbackReflectiveWithDataArg("exec", + (BaseData params) -> { + try { + return (CrashReport) ((Minecraft) params.getReflective("_self")) + .addGraphicsAndWorldToCrashReport((CrashReport) params.getReflective("theCrash")); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_addGraphicsAndWorldToCrashReport_32); + + BaseData reflect_Minecraft_method_getMinecraft_33 = new ModData(); + reflect_Minecraft_method_getMinecraft_33.set("methodName", "getMinecraft"); + reflect_Minecraft_method_getMinecraft_33.set("returnType", "Minecraft"); + reflect_Minecraft_method_getMinecraft_33.set("static", true); + reflect_Minecraft_method_getMinecraft_33.set("argnames", new String[] {}); + reflect_Minecraft_method_getMinecraft_33.set("argtypes", new String[] {}); + reflect_Minecraft_method_getMinecraft_33.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (Minecraft) Minecraft.getMinecraft(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getMinecraft_33); + + BaseData reflect_Minecraft_method_isSnooperEnabled_34 = new ModData(); + reflect_Minecraft_method_isSnooperEnabled_34.set("methodName", "isSnooperEnabled"); + reflect_Minecraft_method_isSnooperEnabled_34.set("returnType", "Minecraft"); + reflect_Minecraft_method_isSnooperEnabled_34.set("static", false); + reflect_Minecraft_method_isSnooperEnabled_34.set("argnames", new String[] {}); + reflect_Minecraft_method_isSnooperEnabled_34.set("argtypes", new String[] {}); + reflect_Minecraft_method_isSnooperEnabled_34.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isSnooperEnabled(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isSnooperEnabled_34); + + BaseData reflect_Minecraft_method_setServerData_35 = new ModData(); + reflect_Minecraft_method_setServerData_35.set("methodName", "setServerData"); + reflect_Minecraft_method_setServerData_35.set("returnType", "Minecraft"); + reflect_Minecraft_method_setServerData_35.set("static", false); + reflect_Minecraft_method_setServerData_35.set("argnames", new String[] { "serverDataIn" }); + reflect_Minecraft_method_setServerData_35.set("argtypes", new String[] { "ServerData" }); + reflect_Minecraft_method_setServerData_35.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .setServerData((ServerData) params.getReflective("serverDataIn")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_setServerData_35); + + BaseData reflect_Minecraft_method_getCurrentServerData_36 = new ModData(); + reflect_Minecraft_method_getCurrentServerData_36.set("methodName", "getCurrentServerData"); + reflect_Minecraft_method_getCurrentServerData_36.set("returnType", "Minecraft"); + reflect_Minecraft_method_getCurrentServerData_36.set("static", false); + reflect_Minecraft_method_getCurrentServerData_36.set("argnames", new String[] {}); + reflect_Minecraft_method_getCurrentServerData_36.set("argtypes", new String[] {}); + reflect_Minecraft_method_getCurrentServerData_36.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ServerData) ((Minecraft) params.getReflective("_self")).getCurrentServerData(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getCurrentServerData_36); + + BaseData reflect_Minecraft_method_isIntegratedServerRunning_37 = new ModData(); + reflect_Minecraft_method_isIntegratedServerRunning_37.set("methodName", "isIntegratedServerRunning"); + reflect_Minecraft_method_isIntegratedServerRunning_37.set("returnType", "Minecraft"); + reflect_Minecraft_method_isIntegratedServerRunning_37.set("static", false); + reflect_Minecraft_method_isIntegratedServerRunning_37.set("argnames", new String[] {}); + reflect_Minecraft_method_isIntegratedServerRunning_37.set("argtypes", new String[] {}); + reflect_Minecraft_method_isIntegratedServerRunning_37.setCallbackBooleanWithDataArg("exec", + (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isIntegratedServerRunning(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isIntegratedServerRunning_37); + + BaseData reflect_Minecraft_method_isSingleplayer_38 = new ModData(); + reflect_Minecraft_method_isSingleplayer_38.set("methodName", "isSingleplayer"); + reflect_Minecraft_method_isSingleplayer_38.set("returnType", "Minecraft"); + reflect_Minecraft_method_isSingleplayer_38.set("static", false); + reflect_Minecraft_method_isSingleplayer_38.set("argnames", new String[] {}); + reflect_Minecraft_method_isSingleplayer_38.set("argtypes", new String[] {}); + reflect_Minecraft_method_isSingleplayer_38.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isSingleplayer(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isSingleplayer_38); + + BaseData reflect_Minecraft_method_stopIntegratedServer_39 = new ModData(); + reflect_Minecraft_method_stopIntegratedServer_39.set("methodName", "stopIntegratedServer"); + reflect_Minecraft_method_stopIntegratedServer_39.set("returnType", "Minecraft"); + reflect_Minecraft_method_stopIntegratedServer_39.set("static", true); + reflect_Minecraft_method_stopIntegratedServer_39.set("argnames", new String[] {}); + reflect_Minecraft_method_stopIntegratedServer_39.set("argtypes", new String[] {}); + reflect_Minecraft_method_stopIntegratedServer_39.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + Minecraft.stopIntegratedServer(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_stopIntegratedServer_39); + + BaseData reflect_Minecraft_method_getSystemTime_40 = new ModData(); + reflect_Minecraft_method_getSystemTime_40.set("methodName", "getSystemTime"); + reflect_Minecraft_method_getSystemTime_40.set("returnType", "Minecraft"); + reflect_Minecraft_method_getSystemTime_40.set("static", true); + reflect_Minecraft_method_getSystemTime_40.set("argnames", new String[] {}); + reflect_Minecraft_method_getSystemTime_40.set("argtypes", new String[] {}); + reflect_Minecraft_method_getSystemTime_40.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (long) Minecraft.getSystemTime(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getSystemTime_40); + + BaseData reflect_Minecraft_method_isFullScreen_41 = new ModData(); + reflect_Minecraft_method_isFullScreen_41.set("methodName", "isFullScreen"); + reflect_Minecraft_method_isFullScreen_41.set("returnType", "Minecraft"); + reflect_Minecraft_method_isFullScreen_41.set("static", false); + reflect_Minecraft_method_isFullScreen_41.set("argnames", new String[] {}); + reflect_Minecraft_method_isFullScreen_41.set("argtypes", new String[] {}); + reflect_Minecraft_method_isFullScreen_41.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isFullScreen(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isFullScreen_41); + + BaseData reflect_Minecraft_method_getSession_42 = new ModData(); + reflect_Minecraft_method_getSession_42.set("methodName", "getSession"); + reflect_Minecraft_method_getSession_42.set("returnType", "Minecraft"); + reflect_Minecraft_method_getSession_42.set("static", false); + reflect_Minecraft_method_getSession_42.set("argnames", new String[] {}); + reflect_Minecraft_method_getSession_42.set("argtypes", new String[] {}); + reflect_Minecraft_method_getSession_42.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (Session) ((Minecraft) params.getReflective("_self")).getSession(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getSession_42); + + BaseData reflect_Minecraft_method_getTextureManager_43 = new ModData(); + reflect_Minecraft_method_getTextureManager_43.set("methodName", "getTextureManager"); + reflect_Minecraft_method_getTextureManager_43.set("returnType", "Minecraft"); + reflect_Minecraft_method_getTextureManager_43.set("static", false); + reflect_Minecraft_method_getTextureManager_43.set("argnames", new String[] {}); + reflect_Minecraft_method_getTextureManager_43.set("argtypes", new String[] {}); + reflect_Minecraft_method_getTextureManager_43.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (TextureManager) ((Minecraft) params.getReflective("_self")).getTextureManager(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getTextureManager_43); + + BaseData reflect_Minecraft_method_getResourceManager_44 = new ModData(); + reflect_Minecraft_method_getResourceManager_44.set("methodName", "getResourceManager"); + reflect_Minecraft_method_getResourceManager_44.set("returnType", "Minecraft"); + reflect_Minecraft_method_getResourceManager_44.set("static", false); + reflect_Minecraft_method_getResourceManager_44.set("argnames", new String[] {}); + reflect_Minecraft_method_getResourceManager_44.set("argtypes", new String[] {}); + reflect_Minecraft_method_getResourceManager_44.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (IResourceManager) ((Minecraft) params.getReflective("_self")).getResourceManager(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getResourceManager_44); + + BaseData reflect_Minecraft_method_getResourcePackRepository_45 = new ModData(); + reflect_Minecraft_method_getResourcePackRepository_45.set("methodName", "getResourcePackRepository"); + reflect_Minecraft_method_getResourcePackRepository_45.set("returnType", "Minecraft"); + reflect_Minecraft_method_getResourcePackRepository_45.set("static", false); + reflect_Minecraft_method_getResourcePackRepository_45.set("argnames", new String[] {}); + reflect_Minecraft_method_getResourcePackRepository_45.set("argtypes", new String[] {}); + reflect_Minecraft_method_getResourcePackRepository_45.setCallbackReflectiveWithDataArg("exec", + (BaseData params) -> { + try { + return (ResourcePackRepository) ((Minecraft) params.getReflective("_self")) + .getResourcePackRepository(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getResourcePackRepository_45); + + BaseData reflect_Minecraft_method_getLanguageManager_46 = new ModData(); + reflect_Minecraft_method_getLanguageManager_46.set("methodName", "getLanguageManager"); + reflect_Minecraft_method_getLanguageManager_46.set("returnType", "Minecraft"); + reflect_Minecraft_method_getLanguageManager_46.set("static", false); + reflect_Minecraft_method_getLanguageManager_46.set("argnames", new String[] {}); + reflect_Minecraft_method_getLanguageManager_46.set("argtypes", new String[] {}); + reflect_Minecraft_method_getLanguageManager_46.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (LanguageManager) ((Minecraft) params.getReflective("_self")).getLanguageManager(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getLanguageManager_46); + + BaseData reflect_Minecraft_method_getTextureMapBlocks_47 = new ModData(); + reflect_Minecraft_method_getTextureMapBlocks_47.set("methodName", "getTextureMapBlocks"); + reflect_Minecraft_method_getTextureMapBlocks_47.set("returnType", "Minecraft"); + reflect_Minecraft_method_getTextureMapBlocks_47.set("static", false); + reflect_Minecraft_method_getTextureMapBlocks_47.set("argnames", new String[] {}); + reflect_Minecraft_method_getTextureMapBlocks_47.set("argtypes", new String[] {}); + reflect_Minecraft_method_getTextureMapBlocks_47.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (TextureMap) ((Minecraft) params.getReflective("_self")).getTextureMapBlocks(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getTextureMapBlocks_47); + + BaseData reflect_Minecraft_method_isJava64bit_48 = new ModData(); + reflect_Minecraft_method_isJava64bit_48.set("methodName", "isJava64bit"); + reflect_Minecraft_method_isJava64bit_48.set("returnType", "Minecraft"); + reflect_Minecraft_method_isJava64bit_48.set("static", false); + reflect_Minecraft_method_isJava64bit_48.set("argnames", new String[] {}); + reflect_Minecraft_method_isJava64bit_48.set("argtypes", new String[] {}); + reflect_Minecraft_method_isJava64bit_48.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isJava64bit(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isJava64bit_48); + + BaseData reflect_Minecraft_method_isGamePaused_49 = new ModData(); + reflect_Minecraft_method_isGamePaused_49.set("methodName", "isGamePaused"); + reflect_Minecraft_method_isGamePaused_49.set("returnType", "Minecraft"); + reflect_Minecraft_method_isGamePaused_49.set("static", false); + reflect_Minecraft_method_isGamePaused_49.set("argnames", new String[] {}); + reflect_Minecraft_method_isGamePaused_49.set("argtypes", new String[] {}); + reflect_Minecraft_method_isGamePaused_49.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).isGamePaused(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_isGamePaused_49); + + BaseData reflect_Minecraft_method_getSoundHandler_50 = new ModData(); + reflect_Minecraft_method_getSoundHandler_50.set("methodName", "getSoundHandler"); + reflect_Minecraft_method_getSoundHandler_50.set("returnType", "Minecraft"); + reflect_Minecraft_method_getSoundHandler_50.set("static", false); + reflect_Minecraft_method_getSoundHandler_50.set("argnames", new String[] {}); + reflect_Minecraft_method_getSoundHandler_50.set("argtypes", new String[] {}); + reflect_Minecraft_method_getSoundHandler_50.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (SoundHandler) ((Minecraft) params.getReflective("_self")).getSoundHandler(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getSoundHandler_50); + + BaseData reflect_Minecraft_method_dispatchKeypresses_51 = new ModData(); + reflect_Minecraft_method_dispatchKeypresses_51.set("methodName", "dispatchKeypresses"); + reflect_Minecraft_method_dispatchKeypresses_51.set("returnType", "Minecraft"); + reflect_Minecraft_method_dispatchKeypresses_51.set("static", false); + reflect_Minecraft_method_dispatchKeypresses_51.set("argnames", new String[] {}); + reflect_Minecraft_method_dispatchKeypresses_51.set("argtypes", new String[] {}); + reflect_Minecraft_method_dispatchKeypresses_51.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).dispatchKeypresses(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_dispatchKeypresses_51); + + BaseData reflect_Minecraft_method_getRenderViewEntity_52 = new ModData(); + reflect_Minecraft_method_getRenderViewEntity_52.set("methodName", "getRenderViewEntity"); + reflect_Minecraft_method_getRenderViewEntity_52.set("returnType", "Minecraft"); + reflect_Minecraft_method_getRenderViewEntity_52.set("static", false); + reflect_Minecraft_method_getRenderViewEntity_52.set("argnames", new String[] {}); + reflect_Minecraft_method_getRenderViewEntity_52.set("argtypes", new String[] {}); + reflect_Minecraft_method_getRenderViewEntity_52.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (Entity) ((Minecraft) params.getReflective("_self")).getRenderViewEntity(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getRenderViewEntity_52); + + BaseData reflect_Minecraft_method_setRenderViewEntity_53 = new ModData(); + reflect_Minecraft_method_setRenderViewEntity_53.set("methodName", "setRenderViewEntity"); + reflect_Minecraft_method_setRenderViewEntity_53.set("returnType", "Minecraft"); + reflect_Minecraft_method_setRenderViewEntity_53.set("static", false); + reflect_Minecraft_method_setRenderViewEntity_53.set("argnames", new String[] { "viewingEntity" }); + reflect_Minecraft_method_setRenderViewEntity_53.set("argtypes", new String[] { "Entity" }); + reflect_Minecraft_method_setRenderViewEntity_53.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .setRenderViewEntity((Entity) params.getReflective("viewingEntity")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_setRenderViewEntity_53); + + BaseData reflect_Minecraft_method_addScheduledTask_54 = new ModData(); + reflect_Minecraft_method_addScheduledTask_54.set("methodName", "addScheduledTask"); + reflect_Minecraft_method_addScheduledTask_54.set("returnType", "Minecraft"); + reflect_Minecraft_method_addScheduledTask_54.set("static", false); + reflect_Minecraft_method_addScheduledTask_54.set("argnames", new String[] { "runnableToSchedule" }); + reflect_Minecraft_method_addScheduledTask_54.set("argtypes", new String[] { "Runnable" }); + reflect_Minecraft_method_addScheduledTask_54.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")) + .addScheduledTask((Runnable) params.getReflective("runnableToSchedule")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_addScheduledTask_54); + + BaseData reflect_Minecraft_method_getBlockRendererDispatcher_55 = new ModData(); + reflect_Minecraft_method_getBlockRendererDispatcher_55.set("methodName", "getBlockRendererDispatcher"); + reflect_Minecraft_method_getBlockRendererDispatcher_55.set("returnType", "Minecraft"); + reflect_Minecraft_method_getBlockRendererDispatcher_55.set("static", false); + reflect_Minecraft_method_getBlockRendererDispatcher_55.set("argnames", new String[] {}); + reflect_Minecraft_method_getBlockRendererDispatcher_55.set("argtypes", new String[] {}); + reflect_Minecraft_method_getBlockRendererDispatcher_55.setCallbackReflectiveWithDataArg("exec", + (BaseData params) -> { + try { + return (BlockRendererDispatcher) ((Minecraft) params.getReflective("_self")) + .getBlockRendererDispatcher(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getBlockRendererDispatcher_55); + + BaseData reflect_Minecraft_method_getRenderManager_56 = new ModData(); + reflect_Minecraft_method_getRenderManager_56.set("methodName", "getRenderManager"); + reflect_Minecraft_method_getRenderManager_56.set("returnType", "Minecraft"); + reflect_Minecraft_method_getRenderManager_56.set("static", false); + reflect_Minecraft_method_getRenderManager_56.set("argnames", new String[] {}); + reflect_Minecraft_method_getRenderManager_56.set("argtypes", new String[] {}); + reflect_Minecraft_method_getRenderManager_56.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (RenderManager) ((Minecraft) params.getReflective("_self")).getRenderManager(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getRenderManager_56); + + BaseData reflect_Minecraft_method_getRenderItem_57 = new ModData(); + reflect_Minecraft_method_getRenderItem_57.set("methodName", "getRenderItem"); + reflect_Minecraft_method_getRenderItem_57.set("returnType", "Minecraft"); + reflect_Minecraft_method_getRenderItem_57.set("static", false); + reflect_Minecraft_method_getRenderItem_57.set("argnames", new String[] {}); + reflect_Minecraft_method_getRenderItem_57.set("argtypes", new String[] {}); + reflect_Minecraft_method_getRenderItem_57.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (RenderItem) ((Minecraft) params.getReflective("_self")).getRenderItem(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getRenderItem_57); + + BaseData reflect_Minecraft_method_getItemRenderer_58 = new ModData(); + reflect_Minecraft_method_getItemRenderer_58.set("methodName", "getItemRenderer"); + reflect_Minecraft_method_getItemRenderer_58.set("returnType", "Minecraft"); + reflect_Minecraft_method_getItemRenderer_58.set("static", false); + reflect_Minecraft_method_getItemRenderer_58.set("argnames", new String[] {}); + reflect_Minecraft_method_getItemRenderer_58.set("argtypes", new String[] {}); + reflect_Minecraft_method_getItemRenderer_58.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ItemRenderer) ((Minecraft) params.getReflective("_self")).getItemRenderer(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getItemRenderer_58); + + BaseData reflect_Minecraft_method_getDebugFPS_59 = new ModData(); + reflect_Minecraft_method_getDebugFPS_59.set("methodName", "getDebugFPS"); + reflect_Minecraft_method_getDebugFPS_59.set("returnType", "Minecraft"); + reflect_Minecraft_method_getDebugFPS_59.set("static", true); + reflect_Minecraft_method_getDebugFPS_59.set("argnames", new String[] {}); + reflect_Minecraft_method_getDebugFPS_59.set("argtypes", new String[] {}); + reflect_Minecraft_method_getDebugFPS_59.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) Minecraft.getDebugFPS(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getDebugFPS_59); + + BaseData reflect_Minecraft_method_func_181539_aj_60 = new ModData(); + reflect_Minecraft_method_func_181539_aj_60.set("methodName", "func_181539_aj"); + reflect_Minecraft_method_func_181539_aj_60.set("returnType", "Minecraft"); + reflect_Minecraft_method_func_181539_aj_60.set("static", false); + reflect_Minecraft_method_func_181539_aj_60.set("argnames", new String[] {}); + reflect_Minecraft_method_func_181539_aj_60.set("argtypes", new String[] {}); + reflect_Minecraft_method_func_181539_aj_60.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (FrameTimer) ((Minecraft) params.getReflective("_self")).func_181539_aj(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_func_181539_aj_60); + + BaseData reflect_Minecraft_method_func_181540_al_61 = new ModData(); + reflect_Minecraft_method_func_181540_al_61.set("methodName", "func_181540_al"); + reflect_Minecraft_method_func_181540_al_61.set("returnType", "Minecraft"); + reflect_Minecraft_method_func_181540_al_61.set("static", false); + reflect_Minecraft_method_func_181540_al_61.set("argnames", new String[] {}); + reflect_Minecraft_method_func_181540_al_61.set("argtypes", new String[] {}); + reflect_Minecraft_method_func_181540_al_61.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).func_181540_al(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_func_181540_al_61); + + BaseData reflect_Minecraft_method_func_181537_a_62 = new ModData(); + reflect_Minecraft_method_func_181537_a_62.set("methodName", "func_181537_a"); + reflect_Minecraft_method_func_181537_a_62.set("returnType", "Minecraft"); + reflect_Minecraft_method_func_181537_a_62.set("static", false); + reflect_Minecraft_method_func_181537_a_62.set("argnames", new String[] { "parFlag" }); + reflect_Minecraft_method_func_181537_a_62.set("argtypes", new String[] { "boolean" }); + reflect_Minecraft_method_func_181537_a_62.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).func_181537_a((boolean) params.getBoolean("parFlag")); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_func_181537_a_62); + + BaseData reflect_Minecraft_method_getGLMaximumTextureSize_63 = new ModData(); + reflect_Minecraft_method_getGLMaximumTextureSize_63.set("methodName", "getGLMaximumTextureSize"); + reflect_Minecraft_method_getGLMaximumTextureSize_63.set("returnType", "Minecraft"); + reflect_Minecraft_method_getGLMaximumTextureSize_63.set("static", true); + reflect_Minecraft_method_getGLMaximumTextureSize_63.set("argnames", new String[] {}); + reflect_Minecraft_method_getGLMaximumTextureSize_63.set("argtypes", new String[] {}); + reflect_Minecraft_method_getGLMaximumTextureSize_63.setCallbackIntWithDataArg("exec", (BaseData params) -> { + try { + return (int) Minecraft.getGLMaximumTextureSize(); + } catch (Exception _exception_reflect_) { + return 0; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getGLMaximumTextureSize_63); + + BaseData reflect_Minecraft_method_areKeysLocked_64 = new ModData(); + reflect_Minecraft_method_areKeysLocked_64.set("methodName", "areKeysLocked"); + reflect_Minecraft_method_areKeysLocked_64.set("returnType", "Minecraft"); + reflect_Minecraft_method_areKeysLocked_64.set("static", false); + reflect_Minecraft_method_areKeysLocked_64.set("argnames", new String[] {}); + reflect_Minecraft_method_areKeysLocked_64.set("argtypes", new String[] {}); + reflect_Minecraft_method_areKeysLocked_64.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).areKeysLocked(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_areKeysLocked_64); + + BaseData reflect_Minecraft_method_getModelManager_65 = new ModData(); + reflect_Minecraft_method_getModelManager_65.set("methodName", "getModelManager"); + reflect_Minecraft_method_getModelManager_65.set("returnType", "Minecraft"); + reflect_Minecraft_method_getModelManager_65.set("static", false); + reflect_Minecraft_method_getModelManager_65.set("argnames", new String[] {}); + reflect_Minecraft_method_getModelManager_65.set("argtypes", new String[] {}); + reflect_Minecraft_method_getModelManager_65.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ModelManager) ((Minecraft) params.getReflective("_self")).getModelManager(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getModelManager_65); + + BaseData reflect_Minecraft_method_getSaveLoader_66 = new ModData(); + reflect_Minecraft_method_getSaveLoader_66.set("methodName", "getSaveLoader"); + reflect_Minecraft_method_getSaveLoader_66.set("returnType", "Minecraft"); + reflect_Minecraft_method_getSaveLoader_66.set("static", false); + reflect_Minecraft_method_getSaveLoader_66.set("argnames", new String[] {}); + reflect_Minecraft_method_getSaveLoader_66.set("argtypes", new String[] {}); + reflect_Minecraft_method_getSaveLoader_66.setCallbackReflectiveWithDataArg("exec", (BaseData params) -> { + try { + return (ISaveFormat) ((Minecraft) params.getReflective("_self")).getSaveLoader(); + } catch (Exception _exception_reflect_) { + return null; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getSaveLoader_66); + + BaseData reflect_Minecraft_method_clearTitles_67 = new ModData(); + reflect_Minecraft_method_clearTitles_67.set("methodName", "clearTitles"); + reflect_Minecraft_method_clearTitles_67.set("returnType", "Minecraft"); + reflect_Minecraft_method_clearTitles_67.set("static", false); + reflect_Minecraft_method_clearTitles_67.set("argnames", new String[] {}); + reflect_Minecraft_method_clearTitles_67.set("argtypes", new String[] {}); + reflect_Minecraft_method_clearTitles_67.setCallbackVoidWithDataArg("exec", (BaseData params) -> { + try { + ((Minecraft) params.getReflective("_self")).clearTitles(); + } catch (Exception _exception_reflect_) { + return; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_clearTitles_67); + + BaseData reflect_Minecraft_method_getEnableFNAWSkins_68 = new ModData(); + reflect_Minecraft_method_getEnableFNAWSkins_68.set("methodName", "getEnableFNAWSkins"); + reflect_Minecraft_method_getEnableFNAWSkins_68.set("returnType", "Minecraft"); + reflect_Minecraft_method_getEnableFNAWSkins_68.set("static", false); + reflect_Minecraft_method_getEnableFNAWSkins_68.set("argnames", new String[] {}); + reflect_Minecraft_method_getEnableFNAWSkins_68.set("argtypes", new String[] {}); + reflect_Minecraft_method_getEnableFNAWSkins_68.setCallbackBooleanWithDataArg("exec", (BaseData params) -> { + try { + return (boolean) ((Minecraft) params.getReflective("_self")).getEnableFNAWSkins(); + } catch (Exception _exception_reflect_) { + return false; + } + }); + + reflect_Minecraft_methods.add(reflect_Minecraft_method_getEnableFNAWSkins_68); + + BaseData[] reflect_Minecraft_methods_arr = new BaseData[reflect_Minecraft_methods.size()]; + for (int i = 0; i < reflect_Minecraft_methods_arr.length; i++) { + reflect_Minecraft_methods_arr[i] = reflect_Minecraft_methods.get(i); + } + + reflect_Minecraft.set("constructors", reflect_Minecraft_constructors_arr); + reflect_Minecraft.set("methods", reflect_Minecraft_methods_arr); + reflect_Minecraft.set("className", "Minecraft"); + reflect_Minecraft.set("classId", "net.minecraft.client.Minecraft"); + reflect_Minecraft.set("class", Minecraft.class); + reflectProfiles.add(reflect_Minecraft); + + BaseData[] reflectProfilesArr = new BaseData[reflectProfiles.size()]; + for (int i = 0; i < reflectProfilesArr.length; i++) { + reflectProfilesArr[i] = reflectProfiles.get(i); + } + plReflectGlobal.set("classes", reflectProfilesArr); + + plReflectGlobal.setCallbackClassFinder("getClassByName", (String className) -> { + for (int i = 0; i < reflectProfilesArr.length; i++) { + if (reflectProfilesArr[i].getString("className").equals(className)) { + return reflectProfilesArr[i]; + } + } + return null; + }); + + plReflectGlobal.setCallbackClassFinder("getClassById", (String classId) -> { + for (int i = 0; i < reflectProfilesArr.length; i++) { + if (reflectProfilesArr[i].getString("classId").equals(classId)) { + return reflectProfilesArr[i]; + } + } + return null; + }); + + return plReflectGlobal; + } +} \ No newline at end of file diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/Display.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/Display.java index 6f40077..956ae1e 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/Display.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/Display.java @@ -49,6 +49,10 @@ public class Display { PlatformInput.setVSync(enable); } + public static boolean isVSyncSupported() { + return PlatformInput.isVSyncSupported(); + } + public static void update() { PlatformInput.update(); } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/EaglercraftVersion.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/EaglercraftVersion.java index a87f0c2..60a0031 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/EaglercraftVersion.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/EaglercraftVersion.java @@ -1,5 +1,6 @@ package net.lax1dude.eaglercraft.v1_8; +import net.lax1dude.eaglercraft.v1_8.internal.PlatformRuntime; import java.math.BigInteger; import static net.eaglerforge.api.ModLoader.returntotalloadedmods; @@ -12,7 +13,7 @@ public class EaglercraftVersion { /// Customize these to fit your fork: public static final String projectForkName = "EaglerForge"; - public static final String projectForkVersion = "v1.3.1"; + public static final String projectForkVersion = "v1.3.2"; public static final String projectForkVendor = "radmanplays"; public static final String projectForkURL = "https://github.com/eaglerforge/EaglerForge"; @@ -22,7 +23,7 @@ public class EaglercraftVersion { public static final String projectOriginName = "EaglercraftX"; public static final String projectOriginAuthor = "lax1dude"; public static final String projectOriginRevision = "1.8"; - public static final String projectOriginVersion = "u29"; + public static final String projectOriginVersion = "u31"; public static final String projectOriginURL = "https://gitlab.com/lax1dude/eaglercraftx-1.8"; // rest in peace @@ -43,9 +44,20 @@ public class EaglercraftVersion { // Miscellaneous variables: - public static int loadedmods = returntotalloadedmods(); public static final String mainMenuStringA = "Minecraft* 1.8.8"; - public static String mainMenuStringB = projectForkName + " " + projectForkVersion + " (" + loadedmods + " Mods loaded)"; + public static String getMainMenuStringB() { + int loadedmods = returntotalloadedmods(); + String mainMenuStringB = projectForkName + " " + projectForkVersion; + if(!PlatformRuntime.isDebugRuntime()) { + if(loadedmods == 1) { + mainMenuStringB = mainMenuStringB + " (" + loadedmods + " Mod loaded)"; + } else { + mainMenuStringB = mainMenuStringB + " (" + loadedmods + " Mods loaded)"; + } + } + + return mainMenuStringB; + } public static final String mainMenuStringC = ""; public static final String mainMenuStringD = "Resources Copyright Mojang AB"; @@ -61,4 +73,6 @@ public class EaglercraftVersion { public static final boolean forceDemoMode = false; + public static final String localStorageNamespace = "_eaglercraftX"; + } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapter.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapter.java index 684275c..d2e0492 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapter.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapter.java @@ -69,4 +69,11 @@ public interface IClientConfigAdapter { boolean isEnableSignatureBadge(); boolean isAllowVoiceClient(); + + boolean isAllowFNAWSkins(); + + String getLocalStorageNamespace(); + + IClientConfigAdapterHooks getHooks(); + } diff --git a/sources/teavm/java/net/lax1dude/eaglercraft/v1_8/internal/teavm/opts/JSEaglercraftXOptsServersArray.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapterHooks.java similarity index 73% rename from sources/teavm/java/net/lax1dude/eaglercraft/v1_8/internal/teavm/opts/JSEaglercraftXOptsServersArray.java rename to sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapterHooks.java index 3299302..397f8b5 100644 --- a/sources/teavm/java/net/lax1dude/eaglercraft/v1_8/internal/teavm/opts/JSEaglercraftXOptsServersArray.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/internal/IClientConfigAdapterHooks.java @@ -1,8 +1,4 @@ -package net.lax1dude.eaglercraft.v1_8.internal.teavm.opts; - -import org.teavm.jso.JSIndexer; -import org.teavm.jso.JSObject; -import org.teavm.jso.JSProperty; +package net.lax1dude.eaglercraft.v1_8.internal; /** * Copyright (c) 2024 lax1dude. All Rights Reserved. @@ -19,12 +15,10 @@ import org.teavm.jso.JSProperty; * POSSIBILITY OF SUCH DAMAGE. * */ -public interface JSEaglercraftXOptsServersArray extends JSObject { +public interface IClientConfigAdapterHooks { - @JSIndexer - JSEaglercraftXOptsServer get(int idx); + void callLocalStorageSavedHook(String key, String base64); - @JSProperty - int getLength(); + String callLocalStorageLoadHook(String key); } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/opengl/ext/deferred/BlockVertexIDs.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/opengl/ext/deferred/BlockVertexIDs.java index fd41992..2a00144 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/opengl/ext/deferred/BlockVertexIDs.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/opengl/ext/deferred/BlockVertexIDs.java @@ -13,6 +13,21 @@ import net.minecraft.client.resources.IResourceManager; import net.minecraft.client.resources.IResourceManagerReloadListener; import net.minecraft.util.ResourceLocation; +/** + * Copyright (c) 2023 lax1dude. All Rights Reserved. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + * + */ public class BlockVertexIDs implements IResourceManagerReloadListener { private static final Logger logger = LogManager.getLogger("BlockVertexIDsCSV"); diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/EaglerSkinTexture.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/EaglerSkinTexture.java index 2b746c1..bea6cf6 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/EaglerSkinTexture.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/EaglerSkinTexture.java @@ -61,7 +61,7 @@ public class EaglerSkinTexture implements ITextureObject { } System.arraycopy(pixels, 0, this.pixels, 0, pixels.length); if(textureId != -1) { - TextureUtil.uploadTextureImageAllocate(textureId, new ImageData(width, height, pixels, true), false, false); + TextureUtil.uploadTextureImageSub(textureId, new ImageData(width, height, pixels, true), 0, 0, false, false); } } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenEditProfile.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenEditProfile.java index fe319bc..d7343b1 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenEditProfile.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenEditProfile.java @@ -73,14 +73,20 @@ public class GuiScreenEditProfile extends GuiScreen { } private void updateOptions() { + DefaultSkins[] arr = DefaultSkins.defaultSkinsMap; + if(!EagRuntime.getConfiguration().isAllowFNAWSkins()) { + DefaultSkins[] arrNoFNAW = new DefaultSkins[arr.length - 5]; + System.arraycopy(arr, 0, arrNoFNAW, 0, arrNoFNAW.length); + arr = arrNoFNAW; + } int numCustom = EaglerProfile.customSkins.size(); - String[] n = new String[numCustom + DefaultSkins.defaultSkinsMap.length]; + String[] n = new String[numCustom + arr.length]; for(int i = 0; i < numCustom; ++i) { n[i] = EaglerProfile.customSkins.get(i).name; } - int numDefault = DefaultSkins.defaultSkinsMap.length; + int numDefault = arr.length; for(int j = 0; j < numDefault; ++j) { - n[numCustom + j] = DefaultSkins.defaultSkinsMap[j].name; + n[numCustom + j] = arr[j].name; } dropDownOptions = n; } @@ -106,6 +112,10 @@ public class GuiScreenEditProfile extends GuiScreen { GlStateManager.translate(skinX + 2, skinY - 9, 0.0f); GlStateManager.scale(0.75f, 0.75f, 0.75f); + if(selectedSlot > dropDownOptions.length - 1) { + selectedSlot = 0; + } + int numberOfCustomSkins = EaglerProfile.customSkins.size(); int skid = selectedSlot - numberOfCustomSkins; SkinModel selectedSkinModel = skid < 0 ? EaglerProfile.customSkins.get(selectedSlot).model : DefaultSkins.getSkinFromId(skid).model; diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportExportProfile.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportExportProfile.java index e709d2d..eed4aae 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportExportProfile.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportExportProfile.java @@ -56,11 +56,15 @@ public class GuiScreenImportExportProfile extends GuiScreen { FileChooserResult result = EagRuntime.getFileChooserResult(); if(result != null) { mc.loadingScreen.eaglerShow(I18n.format("settingsBackup.importing.1"), "settingsBackup.importing.2"); + ProfileImporter importer = new ProfileImporter(result.fileData); try { - ProfileImporter importer = new ProfileImporter(result.fileData); importer.readHeader(); mc.displayGuiScreen(new GuiScreenImportProfile(importer, back)); }catch(IOException ex) { + try { + importer.close(); + } catch (IOException e) { + } EagRuntime.debugPrintStackTrace(ex); mc.displayGuiScreen(new GuiScreenGenericErrorMessage("settingsBackup.importing.failed.1", "settingsBackup.importing.failed.2", back)); } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportProfile.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportProfile.java index 7eecc81..825974a 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportProfile.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/GuiScreenImportProfile.java @@ -62,6 +62,14 @@ public class GuiScreenImportProfile extends GuiScreen { this.buttonList.add(new GuiButton(1, this.width / 2 - 100, this.height / 4 + 140, I18n.format("gui.cancel"))); } + @Override + public void onGuiClosed() { + try { + importer.close(); + } catch (IOException e) { + } + } + protected void actionPerformed(GuiButton par1GuiButton) { if(par1GuiButton.id == 0) { if(!doImportProfile && !doImportSettings && !doImportServers && !doImportResourcePacks) { diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileExporter.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileExporter.java index c309239..7686683 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileExporter.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileExporter.java @@ -69,98 +69,97 @@ public class ProfileExporter { osb.write(new byte[]{(byte)255,(byte)255,(byte)255,(byte)255}); // this will be replaced with the file count osb.write('G'); - OutputStream os = EaglerZLIB.newGZIPOutputStream(osb); - - os.write(new byte[]{(byte)72,(byte)69,(byte)65,(byte)68}); // HEAD - os.write(new byte[]{(byte)9,(byte)102,(byte)105,(byte)108,(byte)101,(byte)45,(byte)116,(byte)121, - (byte)112,(byte)101}); // 9 + file-type - os.write(new byte[]{(byte)0,(byte)0,(byte)0,(byte)14,(byte)101,(byte)112,(byte)107,(byte)47,(byte)112,(byte)114,(byte)111, - (byte)102,(byte)105,(byte)108,(byte)101,(byte)49,(byte)56,(byte)56}); // 14 + epk/profile188 - os.write('>'); - - os.write(new byte[]{(byte)72,(byte)69,(byte)65,(byte)68}); // HEAD - os.write(new byte[]{(byte)12,(byte)102,(byte)105,(byte)108,(byte)101,(byte)45,(byte)101,(byte)120, - (byte)112,(byte)111,(byte)114,(byte)116,(byte)115,(byte)0,(byte)0,(byte)0,(byte)1}); // 12 + file-exports + 1 - os.write((doExportProfile ? 1 : 0) | (doExportSettings ? 2 : 0) | (doExportServers ? 4 : 0) | (doExportResourcePacks ? 8 : 0)); - os.write('>'); - int fileCount = 2; - - if(doExportProfile) { - byte[] profileData = EaglerProfile.write(); - if(profileData == null) { - throw new IOException("Could not write profile data!"); - } - exportFileToEPK("_eaglercraftX.p", profileData, os); - ++fileCount; - } - - if(doExportSettings) { - logger.info("Exporting game settings..."); - byte[] gameSettings = Minecraft.getMinecraft().gameSettings.writeOptions(); - if(gameSettings == null) { - throw new IOException("Could not write game settings!"); - } - exportFileToEPK("_eaglercraftX.g", gameSettings, os); - ++fileCount; - logger.info("Exporting relay settings..."); - byte[] relays = RelayManager.relayManager.write(); - if(relays == null) { - throw new IOException("Could not write relay settings!"); - } - exportFileToEPK("_eaglercraftX.r", relays, os); - ++fileCount; - } - - if(doExportServers) { - logger.info("Exporting server list..."); - byte[] servers = ServerList.getServerList().writeServerList(); - if(servers == null) { - throw new IOException("Could not write server list!"); - } - exportFileToEPK("_eaglercraftX.s", servers, os); - ++fileCount; - } - - logger.info("Exporting certificates..."); - UpdateCertificate cert = UpdateService.getClientCertificate(); - if(cert != null) { - exportFileToEPK("certs/main.cert", cert.rawCertData, os); - ++fileCount; - } - Collection updatesExport = UpdateService.getAvailableUpdates(); - int cc = 0; - for(UpdateCertificate cert2 : updatesExport) { - exportFileToEPK("certs/c" + (cc++) + ".cert", cert2.rawCertData, os); - ++fileCount; - } - - if(doExportResourcePacks) { - logger.info("Exporting resource packs..."); - byte[] packManifest = (new VFile2(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json")).getAllBytes(); - if(packManifest != null) { - exportFileToEPK(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json", packManifest, os); + try(OutputStream os = EaglerZLIB.newGZIPOutputStream(osb)) { + os.write(new byte[]{(byte)72,(byte)69,(byte)65,(byte)68}); // HEAD + os.write(new byte[]{(byte)9,(byte)102,(byte)105,(byte)108,(byte)101,(byte)45,(byte)116,(byte)121, + (byte)112,(byte)101}); // 9 + file-type + os.write(new byte[]{(byte)0,(byte)0,(byte)0,(byte)14,(byte)101,(byte)112,(byte)107,(byte)47,(byte)112,(byte)114,(byte)111, + (byte)102,(byte)105,(byte)108,(byte)101,(byte)49,(byte)56,(byte)56}); // 14 + epk/profile188 + os.write('>'); + + os.write(new byte[]{(byte)72,(byte)69,(byte)65,(byte)68}); // HEAD + os.write(new byte[]{(byte)12,(byte)102,(byte)105,(byte)108,(byte)101,(byte)45,(byte)101,(byte)120, + (byte)112,(byte)111,(byte)114,(byte)116,(byte)115,(byte)0,(byte)0,(byte)0,(byte)1}); // 12 + file-exports + 1 + os.write((doExportProfile ? 1 : 0) | (doExportSettings ? 2 : 0) | (doExportServers ? 4 : 0) | (doExportResourcePacks ? 8 : 0)); + os.write('>'); + + + if(doExportProfile) { + byte[] profileData = EaglerProfile.write(); + if(profileData == null) { + throw new IOException("Could not write profile data!"); + } + exportFileToEPK("_eaglercraftX.p", profileData, os); ++fileCount; - VFile2 baseDir = new VFile2(EaglerFolderResourcePack.RESOURCE_PACKS); - List files = baseDir.listFiles(true); - logger.info("({} files to export)", files.size()); - for(int i = 0, l = files.size(); i < l; ++i) { - VFile2 f = files.get(i); - if(f.getPath().equals(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json")) { - continue; - } - exportFileToEPK(f.getPath(), f.getAllBytes(), os); + } + + if(doExportSettings) { + logger.info("Exporting game settings..."); + byte[] gameSettings = Minecraft.getMinecraft().gameSettings.writeOptions(); + if(gameSettings == null) { + throw new IOException("Could not write game settings!"); + } + exportFileToEPK("_eaglercraftX.g", gameSettings, os); + ++fileCount; + logger.info("Exporting relay settings..."); + byte[] relays = RelayManager.relayManager.write(); + if(relays == null) { + throw new IOException("Could not write relay settings!"); + } + exportFileToEPK("_eaglercraftX.r", relays, os); + ++fileCount; + } + + if(doExportServers) { + logger.info("Exporting server list..."); + byte[] servers = ServerList.getServerList().writeServerList(); + if(servers == null) { + throw new IOException("Could not write server list!"); + } + exportFileToEPK("_eaglercraftX.s", servers, os); + ++fileCount; + } + + logger.info("Exporting certificates..."); + UpdateCertificate cert = UpdateService.getClientCertificate(); + if(cert != null) { + exportFileToEPK("certs/main.cert", cert.rawCertData, os); + ++fileCount; + } + Collection updatesExport = UpdateService.getAvailableUpdates(); + int cc = 0; + for(UpdateCertificate cert2 : updatesExport) { + exportFileToEPK("certs/c" + (cc++) + ".cert", cert2.rawCertData, os); + ++fileCount; + } + + if(doExportResourcePacks) { + logger.info("Exporting resource packs..."); + byte[] packManifest = (new VFile2(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json")).getAllBytes(); + if(packManifest != null) { + exportFileToEPK(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json", packManifest, os); ++fileCount; - if(i > 0 && i % 100 == 0) { - logger.info("Exported {} files", i); + VFile2 baseDir = new VFile2(EaglerFolderResourcePack.RESOURCE_PACKS); + List files = baseDir.listFiles(true); + logger.info("({} files to export)", files.size()); + for(int i = 0, l = files.size(); i < l; ++i) { + VFile2 f = files.get(i); + if(f.getPath().equals(EaglerFolderResourcePack.RESOURCE_PACKS + "/manifest.json")) { + continue; + } + exportFileToEPK(f.getPath(), f.getAllBytes(), os); + ++fileCount; + if(i > 0 && i % 100 == 0) { + logger.info("Exported {} files", i); + } } } } + + os.write(new byte[]{(byte)69,(byte)78,(byte)68,(byte)36}); // END$ } - os.write(new byte[]{(byte)69,(byte)78,(byte)68,(byte)36}); // END$ - os.close(); - osb.write(new byte[]{(byte)58,(byte)58,(byte)58,(byte)89,(byte)69,(byte)69,(byte)58,(byte)62}); // :::YEE:> byte[] ret = osb.toByteArray(); diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileImporter.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileImporter.java index e626b69..4758b1c 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileImporter.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/ProfileImporter.java @@ -1,5 +1,6 @@ package net.lax1dude.eaglercraft.v1_8.profile; +import java.io.Closeable; import java.io.IOException; import net.lax1dude.eaglercraft.v1_8.EagRuntime; @@ -29,7 +30,7 @@ import net.minecraft.client.multiplayer.ServerList; * POSSIBILITY OF SUCH DAMAGE. * */ -public class ProfileImporter { +public class ProfileImporter implements Closeable { private static final Logger logger = LogManager.getLogger("ProfileImporter"); @@ -148,4 +149,9 @@ public class ProfileImporter { } logger.info("Import complete!"); } + + @Override + public void close() throws IOException { + epkDecompiler.close(); + } } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/RenderHighPoly.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/RenderHighPoly.java index 035d68e..515b1ea 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/RenderHighPoly.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/RenderHighPoly.java @@ -468,4 +468,13 @@ public class RenderHighPoly extends RenderPlayer { GlStateManager.popMatrix(); } } + + public void renderLivingAt(AbstractClientPlayer abstractclientplayer, double d0, double d1, double d2) { + if (abstractclientplayer.isEntityAlive() && abstractclientplayer.isPlayerSleeping()) { + super.renderLivingAt(abstractclientplayer, d0 - (double) abstractclientplayer.renderOffsetX, + d1 - (double) abstractclientplayer.renderOffsetY, d2 - (double) abstractclientplayer.renderOffsetZ); + } else { + super.renderLivingAt(abstractclientplayer, d0, d1, d2); + } + } } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/SkinModel.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/SkinModel.java index 8dbb655..735deea 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/SkinModel.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/profile/SkinModel.java @@ -46,7 +46,7 @@ public enum SkinModel { private SkinModel(int id, HighPolySkin highPoly) { this.id = id; this.width = 256; - this.height = 128; + this.height = 256; this.profileSkinType = "eagler"; this.sanitize = true; this.highPoly = highPoly; diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/gui/GuiShareToLan.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/gui/GuiShareToLan.java index 9190a4e..cbf896f 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/gui/GuiShareToLan.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/gui/GuiShareToLan.java @@ -156,7 +156,6 @@ public class GuiShareToLan extends GuiScreen { this.mc.ingameGUI.getChatGUI().printChatMessage(new ChatComponentText(I18n.format("lanServer.opened") .replace("$relay$", LANServerController.getCurrentURI()).replace("$code$", code))); } else { - SingleplayerServerController.configureLAN(mc.theWorld.getWorldInfo().getGameType(), false); this.mc.displayGuiScreen(new GuiScreenNoRelays(this, "noRelay.titleFail")); } } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/lan/LANClientNetworkManager.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/lan/LANClientNetworkManager.java index 418d182..d442f9f 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/lan/LANClientNetworkManager.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/lan/LANClientNetworkManager.java @@ -340,9 +340,11 @@ public class LANClientNetworkManager extends EaglercraftNetworkManager { } EaglerInputStream bi = new EaglerInputStream(fullData); int i = (bi.read() << 24) | (bi.read() << 16) | (bi.read() << 8) | bi.read(); - InputStream inflaterInputStream = EaglerZLIB.newInflaterInputStream(bi); fullData = new byte[i]; - int r = IOUtils.readFully(inflaterInputStream, fullData); + int r; + try(InputStream inflaterInputStream = EaglerZLIB.newInflaterInputStream(bi)) { + r = IOUtils.readFully(inflaterInputStream, fullData); + } if (i != r) { logger.warn("Decompressed packet expected size {} differs from actual size {}!", i, r); } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/EaglerIntegratedServerWorker.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/EaglerIntegratedServerWorker.java index c5d87ee..73fb100 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/EaglerIntegratedServerWorker.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/EaglerIntegratedServerWorker.java @@ -479,7 +479,7 @@ public class EaglerIntegratedServerWorker { while(true) { mainLoop(); - EagUtils.sleep(1l); + EagUtils.sleep(0l); } }catch(Throwable tt) { if(tt instanceof ReportedException) { diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/EPKDecompiler.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/EPKDecompiler.java index 10f536e..fb07f6d 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/EPKDecompiler.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/EPKDecompiler.java @@ -1,6 +1,7 @@ package net.lax1dude.eaglercraft.v1_8.sp.server.export; import java.io.ByteArrayInputStream; +import java.io.Closeable; import java.io.IOException; import java.io.InputStream; import java.util.Arrays; @@ -24,7 +25,7 @@ import net.lax1dude.eaglercraft.v1_8.IOUtils; * POSSIBILITY OF SUCH DAMAGE. * */ -public class EPKDecompiler { +public class EPKDecompiler implements Closeable { public static class FileEntry { public final String type; @@ -178,4 +179,9 @@ public class EPKDecompiler { return new String(charIn); } + @Override + public void close() throws IOException { + zis.close(); + } + } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterEPK.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterEPK.java index 5818c77..fc085c0 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterEPK.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterEPK.java @@ -40,44 +40,45 @@ public class WorldConverterEPK { folderName += "_"; worldDir = EaglerIntegratedServerWorker.saveFormat.getSaveLoader(folderName, false).getWorldDirectory(); } - EPKDecompiler dc = new EPKDecompiler(archiveContents); - EPKDecompiler.FileEntry f = null; - int lastProgUpdate = 0; - int prog = 0; - String hasReadType = null; - boolean has152Format = false; - int cnt = 0; - while((f = dc.readFile()) != null) { - byte[] b = f.data; - if(hasReadType == null) { - if (f.type.equals("HEAD") && f.name.equals("file-type") - && ((hasReadType = EPKDecompiler.readASCII(f.data)).equals("epk/world188") - || (has152Format = hasReadType.equals("epk/world152")))) { - if(has152Format) { - logger.warn("World type detected as 1.5.2, it will be converted to 1.8.8 format"); + try(EPKDecompiler dc = new EPKDecompiler(archiveContents)) { + EPKDecompiler.FileEntry f = null; + int lastProgUpdate = 0; + int prog = 0; + String hasReadType = null; + boolean has152Format = false; + int cnt = 0; + while((f = dc.readFile()) != null) { + byte[] b = f.data; + if(hasReadType == null) { + if (f.type.equals("HEAD") && f.name.equals("file-type") + && ((hasReadType = EPKDecompiler.readASCII(f.data)).equals("epk/world188") + || (has152Format = hasReadType.equals("epk/world152")))) { + if(has152Format) { + logger.warn("World type detected as 1.5.2, it will be converted to 1.8.8 format"); + } + continue; + }else { + throw new IOException("file does not contain a singleplayer 1.5.2 or 1.8.8 world!"); } - continue; - }else { - throw new IOException("file does not contain a singleplayer 1.5.2 or 1.8.8 world!"); } - } - if(f.type.equals("FILE")) { - if(f.name.equals("level.dat") || f.name.equals("level.dat_old")) { - NBTTagCompound worldDatNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); - worldDatNBT.getCompoundTag("Data").setString("LevelName", newName); - worldDatNBT.getCompoundTag("Data").setLong("LastPlayed", System.currentTimeMillis()); - EaglerOutputStream tmp = new EaglerOutputStream(); - CompressedStreamTools.writeCompressed(worldDatNBT, tmp); - b = tmp.toByteArray(); - } - VFile2 ff = new VFile2(worldDir, f.name); - ff.setAllBytes(b); - prog += b.length; - ++cnt; - if(prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - logger.info("Extracted {} files, {} bytes from EPK...", cnt, prog); - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.1", prog); + if(f.type.equals("FILE")) { + if(f.name.equals("level.dat") || f.name.equals("level.dat_old")) { + NBTTagCompound worldDatNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); + worldDatNBT.getCompoundTag("Data").setString("LevelName", newName); + worldDatNBT.getCompoundTag("Data").setLong("LastPlayed", System.currentTimeMillis()); + EaglerOutputStream tmp = new EaglerOutputStream(); + CompressedStreamTools.writeCompressed(worldDatNBT, tmp); + b = tmp.toByteArray(); + } + VFile2 ff = new VFile2(worldDir, f.name); + ff.setAllBytes(b); + prog += b.length; + ++cnt; + if(prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + logger.info("Extracted {} files, {} bytes from EPK...", cnt, prog); + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.1", prog); + } } } } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterMCA.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterMCA.java index e027530..b7a6d5b 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterMCA.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/export/WorldConverterMCA.java @@ -50,111 +50,113 @@ public class WorldConverterMCA { folderName += "_"; worldDir = EaglerIntegratedServerWorker.saveFormat.getSaveLoader(folderName, false).getWorldDirectory(); } - ZipInputStream zis = new ZipInputStream(new EaglerInputStream(archiveContents)); - ZipEntry folderNameFile = null; List fileNames = new ArrayList<>(); - while((folderNameFile = zis.getNextEntry()) != null) { - if (folderNameFile.getName().contains("__MACOSX/")) continue; - if (folderNameFile.isDirectory()) continue; - String lowerName = folderNameFile.getName().toLowerCase(); - if (!(lowerName.endsWith(".dat") || lowerName.endsWith(".dat_old") || lowerName.endsWith(".mca") || lowerName.endsWith(".mcr"))) continue; - fileNames.add(folderNameFile.getName().toCharArray()); + try(ZipInputStream zis = new ZipInputStream(new EaglerInputStream(archiveContents))) { + ZipEntry folderNameFile = null; + while((folderNameFile = zis.getNextEntry()) != null) { + if (folderNameFile.getName().contains("__MACOSX/")) continue; + if (folderNameFile.isDirectory()) continue; + String lowerName = folderNameFile.getName().toLowerCase(); + if (!(lowerName.endsWith(".dat") || lowerName.endsWith(".dat_old") || lowerName.endsWith(".mca") || lowerName.endsWith(".mcr"))) continue; + fileNames.add(folderNameFile.getName().toCharArray()); + } } final int[] i = new int[] { 0 }; while(fileNames.get(0).length > i[0] && fileNames.stream().allMatch(w -> w[i[0]] == fileNames.get(0)[i[0]])) i[0]++; int folderPrefixOffset = i[0]; - zis = new ZipInputStream(new EaglerInputStream(archiveContents)); - ZipEntry f = null; - int lastProgUpdate = 0; - int prog = 0; - byte[] bb = new byte[16384]; - while ((f = zis.getNextEntry()) != null) { - if (f.getName().contains("__MACOSX/")) continue; - if (f.isDirectory()) continue; - String lowerName = f.getName().toLowerCase(); - if (!(lowerName.endsWith(".dat") || lowerName.endsWith(".dat_old") || lowerName.endsWith(".mca") || lowerName.endsWith(".mcr") || lowerName.endsWith(".bmp"))) continue; - EaglerOutputStream baos = new EaglerOutputStream(); - int len; - while ((len = zis.read(bb)) != -1) { - baos.write(bb, 0, len); - } - baos.close(); - byte[] b = baos.toByteArray(); - String fileName = f.getName().substring(folderPrefixOffset); - if (fileName.equals("level.dat") || fileName.equals("level.dat_old")) { - NBTTagCompound worldDatNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); - - NBTTagCompound gameRulesNBT = worldDatNBT.getCompoundTag("Data").getCompoundTag("GameRules"); - gameRulesNBT.setString("loadSpawnChunks", (gameRules & 2) != 0 ? "true" : "false"); - String s = (gameRules & 1) != 0 ? "true" : "false"; - gameRulesNBT.setString("bedSpawnPoint", s); - gameRulesNBT.setString("clickToRide", "false"); - gameRulesNBT.setString("clickToSit", s); - gameRulesNBT.setString("colorCodes", s); - gameRulesNBT.setString("doSignEditing", s); - worldDatNBT.getCompoundTag("Data").setTag("GameRules", gameRulesNBT); - - worldDatNBT.getCompoundTag("Data").setString("LevelName", newName); - worldDatNBT.getCompoundTag("Data").setLong("LastPlayed", System.currentTimeMillis()); - EaglerOutputStream bo = new EaglerOutputStream(); - CompressedStreamTools.writeCompressed(worldDatNBT, bo); - b = bo.toByteArray(); - VFile2 ff = new VFile2(worldDir, fileName); - ff.setAllBytes(b); - prog += b.length; - } else if ((fileName.endsWith(".mcr") || fileName.endsWith(".mca")) && (fileName.startsWith("region/") || fileName.startsWith("DIM1/region/") || fileName.startsWith("DIM-1/region/"))) { - VFile2 chunkFolder = new VFile2(worldDir, fileName.startsWith("DIM1") ? "level1" : (fileName.startsWith("DIM-1") ? "level-1" : "level0")); - RegionFile mca = new RegionFile(new RandomAccessMemoryFile(b, b.length)); - int loadChunksCount = 0; - for(int j = 0; j < 32; ++j) { - for(int k = 0; k < 32; ++k) { - if(mca.isChunkSaved(j, k)) { - NBTTagCompound chunkNBT; - NBTTagCompound chunkLevel; - try { - chunkNBT = CompressedStreamTools.read(mca.getChunkDataInputStream(j, k)); - if(!chunkNBT.hasKey("Level", 10)) { - throw new IOException("Chunk is missing level data!"); + try(ZipInputStream zis = new ZipInputStream(new EaglerInputStream(archiveContents))) { + ZipEntry f = null; + int lastProgUpdate = 0; + int prog = 0; + byte[] bb = new byte[16384]; + while ((f = zis.getNextEntry()) != null) { + if (f.getName().contains("__MACOSX/")) continue; + if (f.isDirectory()) continue; + String lowerName = f.getName().toLowerCase(); + if (!(lowerName.endsWith(".dat") || lowerName.endsWith(".dat_old") || lowerName.endsWith(".mca") || lowerName.endsWith(".mcr") || lowerName.endsWith(".bmp"))) continue; + EaglerOutputStream baos = new EaglerOutputStream(); + int len; + while ((len = zis.read(bb)) != -1) { + baos.write(bb, 0, len); + } + baos.close(); + byte[] b = baos.toByteArray(); + String fileName = f.getName().substring(folderPrefixOffset); + if (fileName.equals("level.dat") || fileName.equals("level.dat_old")) { + NBTTagCompound worldDatNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); + + NBTTagCompound gameRulesNBT = worldDatNBT.getCompoundTag("Data").getCompoundTag("GameRules"); + gameRulesNBT.setString("loadSpawnChunks", (gameRules & 2) != 0 ? "true" : "false"); + String s = (gameRules & 1) != 0 ? "true" : "false"; + gameRulesNBT.setString("bedSpawnPoint", s); + gameRulesNBT.setString("clickToRide", "false"); + gameRulesNBT.setString("clickToSit", s); + gameRulesNBT.setString("colorCodes", s); + gameRulesNBT.setString("doSignEditing", s); + worldDatNBT.getCompoundTag("Data").setTag("GameRules", gameRulesNBT); + + worldDatNBT.getCompoundTag("Data").setString("LevelName", newName); + worldDatNBT.getCompoundTag("Data").setLong("LastPlayed", System.currentTimeMillis()); + EaglerOutputStream bo = new EaglerOutputStream(); + CompressedStreamTools.writeCompressed(worldDatNBT, bo); + b = bo.toByteArray(); + VFile2 ff = new VFile2(worldDir, fileName); + ff.setAllBytes(b); + prog += b.length; + } else if ((fileName.endsWith(".mcr") || fileName.endsWith(".mca")) && (fileName.startsWith("region/") || fileName.startsWith("DIM1/region/") || fileName.startsWith("DIM-1/region/"))) { + VFile2 chunkFolder = new VFile2(worldDir, fileName.startsWith("DIM1") ? "level1" : (fileName.startsWith("DIM-1") ? "level-1" : "level0")); + RegionFile mca = new RegionFile(new RandomAccessMemoryFile(b, b.length)); + int loadChunksCount = 0; + for(int j = 0; j < 32; ++j) { + for(int k = 0; k < 32; ++k) { + if(mca.isChunkSaved(j, k)) { + NBTTagCompound chunkNBT; + NBTTagCompound chunkLevel; + try { + chunkNBT = CompressedStreamTools.read(mca.getChunkDataInputStream(j, k)); + if(!chunkNBT.hasKey("Level", 10)) { + throw new IOException("Chunk is missing level data!"); + } + chunkLevel = chunkNBT.getCompoundTag("Level"); + }catch(Throwable t) { + logger.error("{}: Could not read chunk: {}, {}", fileName, j, k); + logger.error(t); + continue; } - chunkLevel = chunkNBT.getCompoundTag("Level"); - }catch(Throwable t) { - logger.error("{}: Could not read chunk: {}, {}", fileName, j, k); - logger.error(t); - continue; + int chunkX = chunkLevel.getInteger("xPos"); + int chunkZ = chunkLevel.getInteger("zPos"); + VFile2 chunkOut = new VFile2(chunkFolder, EaglerChunkLoader.getChunkPath(chunkX, chunkZ) + ".dat"); + if(chunkOut.exists()) { + logger.error("{}: Chunk already exists: {}", fileName, chunkOut.getPath()); + continue; + } + EaglerOutputStream bao = new EaglerOutputStream(); + CompressedStreamTools.writeCompressed(chunkNBT, bao); + b = bao.toByteArray(); + chunkOut.setAllBytes(b); + prog += b.length; + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.2", prog); + } + ++loadChunksCount; } - int chunkX = chunkLevel.getInteger("xPos"); - int chunkZ = chunkLevel.getInteger("zPos"); - VFile2 chunkOut = new VFile2(chunkFolder, EaglerChunkLoader.getChunkPath(chunkX, chunkZ) + ".dat"); - if(chunkOut.exists()) { - logger.error("{}: Chunk already exists: {}", fileName, chunkOut.getPath()); - continue; - } - EaglerOutputStream bao = new EaglerOutputStream(); - CompressedStreamTools.writeCompressed(chunkNBT, bao); - b = bao.toByteArray(); - chunkOut.setAllBytes(b); - prog += b.length; - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.2", prog); - } - ++loadChunksCount; } } + logger.info("{}: Imported {} chunks successfully ({} bytes)", fileName, loadChunksCount, prog); + } else if (fileName.startsWith("playerdata/") || fileName.startsWith("stats/")) { + //TODO: LAN player inventories + } else if (fileName.startsWith("data/") || fileName.startsWith("players/") || fileName.startsWith("eagler/skulls/")) { + VFile2 ff = new VFile2(worldDir, fileName); + ff.setAllBytes(b); + prog += b.length; + } else if (!fileName.equals("level.dat_mcr") && !fileName.equals("session.lock")) { + logger.info("Skipping file: {}", fileName); + } + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.2", prog); } - logger.info("{}: Imported {} chunks successfully ({} bytes)", fileName, loadChunksCount, prog); - } else if (fileName.startsWith("playerdata/") || fileName.startsWith("stats/")) { - //TODO: LAN player inventories - } else if (fileName.startsWith("data/") || fileName.startsWith("players/") || fileName.startsWith("eagler/skulls/")) { - VFile2 ff = new VFile2(worldDir, fileName); - ff.setAllBytes(b); - prog += b.length; - } else if (!fileName.equals("level.dat_mcr") && !fileName.equals("session.lock")) { - logger.info("Skipping file: {}", fileName); - } - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.importing.2", prog); } } logger.info("MCA was successfully extracted into directory \"{}\"", worldDir.getPath()); @@ -172,129 +174,130 @@ public class WorldConverterMCA { public static byte[] exportWorld(String folderName) throws IOException { EaglerOutputStream bao = new EaglerOutputStream(); - ZipOutputStream zos = new ZipOutputStream(bao); - zos.setComment("contains backup of world '" + folderName + "'"); - VFile2 worldFolder = EaglerIntegratedServerWorker.saveFormat.getSaveLoader(folderName, false).getWorldDirectory(); - logger.info("Exporting world directory \"{}\" as MCA", worldFolder.getPath()); - VFile2 vf = new VFile2(worldFolder, "level.dat"); - byte[] b; - int lastProgUpdate = 0; - int prog = 0; - boolean safe = false; - if(vf.exists()) { - zos.putNextEntry(new ZipEntry(folderName + "/level.dat")); - b = vf.getAllBytes(); - zos.write(b); - prog += b.length; - safe = true; - } - vf = new VFile2(worldFolder, "level.dat_old"); - if(vf.exists()) { - zos.putNextEntry(new ZipEntry(folderName + "/level.dat_old")); - b = vf.getAllBytes(); - zos.write(b); - prog += b.length; - safe = true; - } - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); - } - String[] srcFolderNames = new String[] { "level0", "level-1", "level1" }; - String[] dstFolderNames = new String[] { "/region/", "/DIM-1/region/", "/DIM1/region/" }; - List fileList; - for(int i = 0; i < 3; ++i) { - vf = new VFile2(worldFolder, srcFolderNames[i]); - fileList = vf.listFiles(true); - String regionFolder = folderName + dstFolderNames[i]; - logger.info("Converting chunks in \"{}\" as MCA to \"{}\"...", vf.getPath(), regionFolder); - Map regionFiles = new HashMap(); - for(int k = 0, l = fileList.size(); k < l; ++k) { - VFile2 chunkFile = fileList.get(k); - NBTTagCompound chunkNBT; - NBTTagCompound chunkLevel; - try { - b = chunkFile.getAllBytes(); - chunkNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); - if(!chunkNBT.hasKey("Level", 10)) { - throw new IOException("Chunk is missing level data!"); + VFile2 worldFolder; + try(ZipOutputStream zos = new ZipOutputStream(bao)) { + zos.setComment("contains backup of world '" + folderName + "'"); + worldFolder = EaglerIntegratedServerWorker.saveFormat.getSaveLoader(folderName, false).getWorldDirectory(); + logger.info("Exporting world directory \"{}\" as MCA", worldFolder.getPath()); + VFile2 vf = new VFile2(worldFolder, "level.dat"); + byte[] b; + int lastProgUpdate = 0; + int prog = 0; + boolean safe = false; + if(vf.exists()) { + zos.putNextEntry(new ZipEntry(folderName + "/level.dat")); + b = vf.getAllBytes(); + zos.write(b); + prog += b.length; + safe = true; + } + vf = new VFile2(worldFolder, "level.dat_old"); + if(vf.exists()) { + zos.putNextEntry(new ZipEntry(folderName + "/level.dat_old")); + b = vf.getAllBytes(); + zos.write(b); + prog += b.length; + safe = true; + } + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); + } + String[] srcFolderNames = new String[] { "level0", "level-1", "level1" }; + String[] dstFolderNames = new String[] { "/region/", "/DIM-1/region/", "/DIM1/region/" }; + List fileList; + for(int i = 0; i < 3; ++i) { + vf = new VFile2(worldFolder, srcFolderNames[i]); + fileList = vf.listFiles(true); + String regionFolder = folderName + dstFolderNames[i]; + logger.info("Converting chunks in \"{}\" as MCA to \"{}\"...", vf.getPath(), regionFolder); + Map regionFiles = new HashMap(); + for(int k = 0, l = fileList.size(); k < l; ++k) { + VFile2 chunkFile = fileList.get(k); + NBTTagCompound chunkNBT; + NBTTagCompound chunkLevel; + try { + b = chunkFile.getAllBytes(); + chunkNBT = CompressedStreamTools.readCompressed(new EaglerInputStream(b)); + if(!chunkNBT.hasKey("Level", 10)) { + throw new IOException("Chunk is missing level data!"); + } + chunkLevel = chunkNBT.getCompoundTag("Level"); + }catch(IOException t) { + logger.error("Could not read chunk: {}", chunkFile.getPath()); + logger.error(t); + continue; } - chunkLevel = chunkNBT.getCompoundTag("Level"); - }catch(IOException t) { - logger.error("Could not read chunk: {}", chunkFile.getPath()); - logger.error(t); + int chunkX = chunkLevel.getInteger("xPos"); + int chunkZ = chunkLevel.getInteger("zPos"); + String regionFileName = "r." + (chunkX >> 5) + "." + (chunkZ >> 5) + ".mca"; + RegionFile rf = regionFiles.get(regionFileName); + if(rf == null) { + rf = new RegionFile(new RandomAccessMemoryFile(new byte[65536], 0)); + regionFiles.put(regionFileName, rf); + } + try(DataOutputStream dos = rf.getChunkDataOutputStream(chunkX & 31, chunkZ & 31)) { + CompressedStreamTools.write(chunkNBT, dos); + }catch(IOException t) { + logger.error("Could not write chunk to {}: {}", regionFileName, chunkFile.getPath()); + logger.error(t); + continue; + } + prog += b.length; + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); + } + } + if(regionFiles.isEmpty()) { + logger.info("No region files were generated"); continue; } - int chunkX = chunkLevel.getInteger("xPos"); - int chunkZ = chunkLevel.getInteger("zPos"); - String regionFileName = "r." + (chunkX >> 5) + "." + (chunkZ >> 5) + ".mca"; - RegionFile rf = regionFiles.get(regionFileName); - if(rf == null) { - rf = new RegionFile(new RandomAccessMemoryFile(new byte[65536], 0)); - regionFiles.put(regionFileName, rf); - } - try(DataOutputStream dos = rf.getChunkDataOutputStream(chunkX & 31, chunkZ & 31)) { - CompressedStreamTools.write(chunkNBT, dos); - }catch(IOException t) { - logger.error("Could not write chunk to {}: {}", regionFileName, chunkFile.getPath()); - logger.error(t); - continue; + for(Entry etr : regionFiles.entrySet()) { + String regionPath = regionFolder + etr.getKey(); + logger.info("Writing region file: {}", regionPath); + zos.putNextEntry(new ZipEntry(regionPath)); + zos.write(etr.getValue().getFile().getByteArray()); } + } + logger.info("Copying extra world data..."); + fileList = (new VFile2(worldFolder, "data")).listFiles(false); + for(int k = 0, l = fileList.size(); k < l; ++k) { + VFile2 dataFile = fileList.get(k); + zos.putNextEntry(new ZipEntry(folderName + "/data/" + dataFile.getName())); + b = dataFile.getAllBytes(); + zos.write(b); prog += b.length; if (prog - lastProgUpdate > 25000) { lastProgUpdate = prog; EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); } } - if(regionFiles.isEmpty()) { - logger.info("No region files were generated"); - continue; + fileList = (new VFile2(worldFolder, "players")).listFiles(false); + for(int k = 0, l = fileList.size(); k < l; ++k) { + VFile2 dataFile = fileList.get(k); + zos.putNextEntry(new ZipEntry(folderName + "/players/" + dataFile.getName())); + b = dataFile.getAllBytes(); + zos.write(b); + prog += b.length; + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); + } } - for(Entry etr : regionFiles.entrySet()) { - String regionPath = regionFolder + etr.getKey(); - logger.info("Writing region file: {}", regionPath); - zos.putNextEntry(new ZipEntry(regionPath)); - zos.write(etr.getValue().getFile().getByteArray()); + fileList = (new VFile2(worldFolder, "eagler/skulls")).listFiles(false); + for(int k = 0, l = fileList.size(); k < l; ++k) { + VFile2 dataFile = fileList.get(k); + zos.putNextEntry(new ZipEntry(folderName + "/eagler/skulls/" + dataFile.getName())); + b = dataFile.getAllBytes(); + zos.write(b); + prog += b.length; + if (prog - lastProgUpdate > 25000) { + lastProgUpdate = prog; + EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); + } } } - logger.info("Copying extra world data..."); - fileList = (new VFile2(worldFolder, "data")).listFiles(false); - for(int k = 0, l = fileList.size(); k < l; ++k) { - VFile2 dataFile = fileList.get(k); - zos.putNextEntry(new ZipEntry(folderName + "/data/" + dataFile.getName())); - b = dataFile.getAllBytes(); - zos.write(b); - prog += b.length; - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); - } - } - fileList = (new VFile2(worldFolder, "players")).listFiles(false); - for(int k = 0, l = fileList.size(); k < l; ++k) { - VFile2 dataFile = fileList.get(k); - zos.putNextEntry(new ZipEntry(folderName + "/players/" + dataFile.getName())); - b = dataFile.getAllBytes(); - zos.write(b); - prog += b.length; - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); - } - } - fileList = (new VFile2(worldFolder, "eagler/skulls")).listFiles(false); - for(int k = 0, l = fileList.size(); k < l; ++k) { - VFile2 dataFile = fileList.get(k); - zos.putNextEntry(new ZipEntry(folderName + "/eagler/skulls/" + dataFile.getName())); - b = dataFile.getAllBytes(); - zos.write(b); - prog += b.length; - if (prog - lastProgUpdate > 25000) { - lastProgUpdate = prog; - EaglerIntegratedServerWorker.sendProgress("singleplayer.busy.exporting.2", prog); - } - } - zos.close(); logger.info("World directory \"{}\" was successfully exported as MCA", worldFolder.getPath()); return bao.toByteArray(); } diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/socket/IntegratedServerPlayerNetworkManager.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/socket/IntegratedServerPlayerNetworkManager.java index 3041090..bccbaee 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/socket/IntegratedServerPlayerNetworkManager.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/sp/server/socket/IntegratedServerPlayerNetworkManager.java @@ -243,9 +243,9 @@ public class IntegratedServerPlayerNetworkManager { temporaryOutputStream.write((len >> 16) & 0xFF); temporaryOutputStream.write((len >> 8) & 0xFF); temporaryOutputStream.write(len & 0xFF); - OutputStream os = EaglerZLIB.newDeflaterOutputStream(temporaryOutputStream); - temporaryBuffer.readBytes(os, len); - os.close(); + try(OutputStream os = EaglerZLIB.newDeflaterOutputStream(temporaryOutputStream)) { + temporaryBuffer.readBytes(os, len); + } compressedData = temporaryOutputStream.toByteArray(); }catch(IOException ex) { logger.error("Failed to compress packet {}!", pkt.getClass().getSimpleName()); diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/RelayUpdateChecker.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/RelayUpdateChecker.java index be5cd15..2ee5eeb 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/RelayUpdateChecker.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/RelayUpdateChecker.java @@ -64,7 +64,7 @@ public class RelayUpdateChecker { for(net.lax1dude.eaglercraft.v1_8.sp.relay.RelayEntry etr : EagRuntime.getConfiguration().getRelays()) { relaysList.add(new RelayEntry(etr.address)); } - byte[] b = PlatformApplication.getLocalStorage("lastRelayUpdate"); + byte[] b = PlatformApplication.getLocalStorage("lastRelayUpdate", false); if(b != null) { try { lastUpdateCheck = (new DataInputStream(new EaglerInputStream(b))).readLong(); @@ -79,7 +79,7 @@ public class RelayUpdateChecker { try { EaglerOutputStream bao = new EaglerOutputStream(8); (new DataOutputStream(bao)).writeLong(lastUpdateCheck); - PlatformApplication.setLocalStorage("lastRelayUpdate", bao.toByteArray()); + PlatformApplication.setLocalStorage("lastRelayUpdate", bao.toByteArray(), false); } catch (IOException e) { } for (int i = 0, l = relaysList.size(); i < l; ++i) { diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateCertificate.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateCertificate.java index 2bfdc43..a3bc785 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateCertificate.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateCertificate.java @@ -148,7 +148,16 @@ public class UpdateCertificate { throw new CertificateInvalidException("SHA256 checksum of signature payload is invalid!"); } - return new UpdateCertificate(certData, EaglerZLIB.newGZIPInputStream(new EaglerInputStream(signaturePayload)), vers); + UpdateCertificate cert; + try(InputStream gis = EaglerZLIB.newGZIPInputStream(new EaglerInputStream(signaturePayload))) { + cert = new UpdateCertificate(certData, gis, vers); + } + + if(System.currentTimeMillis() < cert.sigTimestamp) { + throw new CertificateInvalidException("Update certificate timestamp is from the future!?"); + } + + return cert; } private UpdateCertificate(byte[] certData, InputStream is, int sigVers) throws IOException { diff --git a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateService.java b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateService.java index 49aa9bb..32c1b68 100644 --- a/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateService.java +++ b/sources/main/java/net/lax1dude/eaglercraft/v1_8/update/UpdateService.java @@ -94,7 +94,7 @@ public class UpdateService { } } } - byte[] latestUpdate = PlatformApplication.getLocalStorage(EaglercraftVersion.updateLatestLocalStorageKey); + byte[] latestUpdate = PlatformApplication.getLocalStorage(EaglercraftVersion.updateLatestLocalStorageKey, false); if(latestUpdate != null) { addCertificateToSet(latestUpdate, false); } @@ -150,7 +150,7 @@ public class UpdateService { latestUpdateFound = cert; if (saveLatest) { PlatformApplication.setLocalStorage(EaglercraftVersion.updateLatestLocalStorageKey, - certificateData); + certificateData, false); } } }else if(EagRuntime.getConfiguration().isLogInvalidCerts()) { diff --git a/sources/resources/plugin_download.zip b/sources/resources/plugin_download.zip index 7b99d4b..22d2e39 100644 Binary files a/sources/resources/plugin_download.zip and b/sources/resources/plugin_download.zip differ diff --git a/sources/resources/plugin_version.json b/sources/resources/plugin_version.json index 56a0adb..8e05487 100644 --- a/sources/resources/plugin_version.json +++ b/sources/resources/plugin_version.json @@ -1 +1 @@ -{"pluginName":"EaglercraftXBungee","pluginVersion":"1.1.0","pluginButton":"Download \"EaglerXBungee-1.1.0.jar\"","pluginFilename":"EaglerXBungee.zip"} \ No newline at end of file +{"pluginName":"EaglercraftXBungee","pluginVersion":"1.2.1","pluginButton":"Download \"EaglerXBungee-1.2.1.jar\"","pluginFilename":"EaglerXBungee.zip"} \ No newline at end of file diff --git a/sources/resources/relay_download.zip b/sources/resources/relay_download.zip index 7b644bc..dc97f94 100644 Binary files a/sources/resources/relay_download.zip and b/sources/resources/relay_download.zip differ diff --git a/sources/setup/workspace_template/javascript/OfflineDownloadTemplate.txt b/sources/setup/workspace_template/javascript/OfflineDownloadTemplate.txt index 5eb9b4f..90cdc12 100644 --- a/sources/setup/workspace_template/javascript/OfflineDownloadTemplate.txt +++ b/sources/setup/workspace_template/javascript/OfflineDownloadTemplate.txt @@ -470,20 +470,6 @@ function displayGui() { } - -