This commit is contained in:
eaglercraft 2024-07-04 00:39:59 -07:00 committed by Aether
parent a863b8a73f
commit 26fd32615c
55 changed files with 1941 additions and 1767 deletions

View File

@ -1,4 +1,5 @@
"use strict"; "use strict";
${classes_js}
// %%%%%%%%% launch options %%%%%%%%%%%% // %%%%%%%%% launch options %%%%%%%%%%%%
@ -26,8 +27,6 @@ if(typeof window !== "undefined") {
// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
${classes_js}
if(typeof window !== "undefined") { window.eaglercraftXOpts.enableSignatureBadge = true; window.eaglercraftXOpts.assetsURI = ${assets_epk}; } if(typeof window !== "undefined") { window.eaglercraftXOpts.enableSignatureBadge = true; window.eaglercraftXOpts.assetsURI = ${assets_epk}; }
if(typeof window !== "undefined") setTimeout(() => { if(typeof window !== "undefined") setTimeout(() => {

Binary file not shown.

After

Width:  |  Height:  |  Size: 841 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 860 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 855 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 689 B

View File

@ -46,7 +46,7 @@ uniform float u_blockConstant1f;
#define DO_COMPILE_STATE_WAVING_BLOCKS #define DO_COMPILE_STATE_WAVING_BLOCKS
#define FAKE_SIN(valueIn, valueOut)\ #define FAKE_SIN(valueIn, valueOut)\
valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\ valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\
valueOut = valueOut * valueOut * (3.0 - 2.0 * valueOut) * 2.0 - 1.0; valueOut = valueOut * valueOut * (6.0 - 4.0 * valueOut) - 1.0;
#define LIB_INCLUDE_WAVING_BLOCKS_FUNCTION #define LIB_INCLUDE_WAVING_BLOCKS_FUNCTION
#endif #endif
@ -68,7 +68,6 @@ uniform mat4 u_projectionMat4f;
#define TEX_MAT3(mat4In) mat3(mat4In[0].xyw,mat4In[1].xyw,mat4In[3].xyw) #define TEX_MAT3(mat4In) mat3(mat4In[0].xyw,mat4In[1].xyw,mat4In[3].xyw)
void main() { void main() {
#ifdef COMPILE_TEXTURE_ATTRIB #ifdef COMPILE_TEXTURE_ATTRIB
vec3 v_textureTmp3f = TEX_MAT3(u_textureMat4f01) * vec3(a_texture2f, 1.0); vec3 v_textureTmp3f = TEX_MAT3(u_textureMat4f01) * vec3(a_texture2f, 1.0);
v_texture2f = v_textureTmp3f.xy / v_textureTmp3f.z; v_texture2f = v_textureTmp3f.xy / v_textureTmp3f.z;
@ -112,5 +111,4 @@ void main() {
#endif #endif
gl_Position = u_projectionMat4f * pos; gl_Position = u_projectionMat4f * pos;
} }

View File

@ -53,7 +53,7 @@ uniform vec4 u_wavingBlockParam4f;
#define DO_COMPILE_STATE_WAVING_BLOCKS #define DO_COMPILE_STATE_WAVING_BLOCKS
#define FAKE_SIN(valueIn, valueOut)\ #define FAKE_SIN(valueIn, valueOut)\
valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\ valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\
valueOut = valueOut * valueOut * (3.0 - 2.0 * valueOut) * 2.0 - 1.0; valueOut = valueOut * valueOut * (6.0 - 4.0 * valueOut) - 1.0;
#define LIB_INCLUDE_WAVING_BLOCKS_FUNCTION #define LIB_INCLUDE_WAVING_BLOCKS_FUNCTION
#endif #endif
@ -81,8 +81,7 @@ void main() {
u_textureMat4f02[0].yw, u_textureMat4f02[0].yw,
u_textureMat4f02[1].yw, u_textureMat4f02[1].yw,
u_textureMat4f02[2].yw, u_textureMat4f02[2].yw,
u_textureMat4f02[3].yw u_textureMat4f02[3].yw);
);
vec2 v_lightmapTmp2f = texMat4x2 * vec4(a_lightmap2f, 0.0, 1.0); vec2 v_lightmapTmp2f = texMat4x2 * vec4(a_lightmap2f, 0.0, 1.0);
v_lightmapTmp2f.x = v_lightmapTmp2f.x / v_lightmapTmp2f.y; v_lightmapTmp2f.x = v_lightmapTmp2f.x / v_lightmapTmp2f.y;
#else #else

View File

@ -39,7 +39,7 @@ uniform float u_baseScale1f;
#define FAKE_SIN(valueIn, valueOut)\ #define FAKE_SIN(valueIn, valueOut)\
valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\ valueOut = abs(1.0 - fract(valueIn * 0.159155) * 2.0);\
valueOut = valueOut * valueOut * (3.0 - 2.0 * valueOut) * 2.0 - 1.0; valueOut = valueOut * valueOut * (6.0 - 4.0 * valueOut) - 1.0;
void main() { void main() {
v_occlusion1f = max(textureLod(u_sunOcclusionValue, vec2(0.5, 0.5), 0.0).r * 1.5 - 0.5, 0.0); v_occlusion1f = max(textureLod(u_sunOcclusionValue, vec2(0.5, 0.5), 0.0).r * 1.5 - 0.5, 0.0);

View File

@ -282,4 +282,8 @@ public class PlatformApplication {
} }
public static void setMCServerWindowGlobal(String str) {
}
} }

View File

@ -81,7 +81,7 @@ public class PlatformAssets {
if (!a) { if (!a) {
j = j | 0xFF000000; j = j | 0xFF000000;
} }
pixels[i] = (j & 0xFF00FF00) | ((j & 0x00FF0000) >> 16) | pixels[i] = (j & 0xFF00FF00) | ((j & 0x00FF0000) >>> 16) |
((j & 0x000000FF) << 16); ((j & 0x000000FF) << 16);
} }
return new ImageData(w, h, pixels, a); return new ImageData(w, h, pixels, a);

View File

@ -150,7 +150,7 @@ public class PlatformRuntime {
windowIcons[i].getRGB(0, 0, w, h, px, 0, w); windowIcons[i].getRGB(0, 0, w, h, px, 0, w);
for(int j = 0; j < px.length; ++j) { for(int j = 0; j < px.length; ++j) {
px[j] = (px[j] & 0xFF00FF00) | ((px[j] >> 16) & 0xFF) | ((px[j] & 0xFF) << 16); // swap R/B px[j] = (px[j] & 0xFF00FF00) | ((px[j] >>> 16) & 0xFF) | ((px[j] & 0xFF) << 16); // swap R/B
} }
java.nio.ByteBuffer iconBuffer = st.malloc(w * h * 4); java.nio.ByteBuffer iconBuffer = st.malloc(w * h * 4);

View File

@ -2,6 +2,7 @@ package net.lax1dude.eaglercraft.v1_8.internal.lwjgl;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.Consumer;
import org.json.JSONObject; import org.json.JSONObject;
@ -166,5 +167,10 @@ public class DesktopClientConfigAdapter implements IClientConfigAdapter {
return null; return null;
} }
@Override
public void callCrashReportHook(String crashReport, Consumer<String> customMessageCB) {
}
} }
} }

View File

@ -237,6 +237,9 @@ public class EagRuntime {
return PlatformRuntime.maxMemory(); return PlatformRuntime.maxMemory();
} }
/**
* Note to skids: This doesn't do anything in TeaVM runtime!
*/
public static long totalMemory() { public static long totalMemory() {
return PlatformRuntime.totalMemory(); return PlatformRuntime.totalMemory();
} }
@ -333,4 +336,8 @@ public class EagRuntime {
input.setCalendar(getLocaleCalendar()); input.setCalendar(getLocaleCalendar());
return input; return input;
} }
public static void setMCServerWindowGlobal(String url) {
PlatformApplication.setMCServerWindowGlobal(url);
}
} }

View File

@ -19,8 +19,8 @@ public class EaglercraftVersion {
public static final String projectOriginName = "EaglercraftX"; public static final String projectOriginName = "EaglercraftX";
public static final String projectOriginAuthor = "lax1dude"; public static final String projectOriginAuthor = "lax1dude";
public static final String projectOriginRevision = "1.9.4"; public static final String projectOriginRevision = "1.8";
public static final String projectOriginVersion = "u35"; public static final String projectOriginVersion = "u36";
public static final String projectOriginURL = "https://gitlab.com/lax1dude/eaglercraftx-1.8"; // rest in peace public static final String projectOriginURL = "https://gitlab.com/lax1dude/eaglercraftx-1.8"; // rest in peace
@ -34,7 +34,7 @@ public class EaglercraftVersion {
"https://update.hoosiertransfer.xyz/cert"); "https://update.hoosiertransfer.xyz/cert");
public static final String updateBundlePackageName = "net.lax1dude.eaglercraft.v1_8.client"; public static final String updateBundlePackageName = "net.lax1dude.eaglercraft.v1_8.client";
public static final int updateBundlePackageVersionInt = 2; public static final int updateBundlePackageVersionInt = 3;
public static final String updateLatestLocalStorageKey = "latestUpdate_" + updateBundlePackageName; public static final String updateLatestLocalStorageKey = "latestUpdate_" + updateBundlePackageName;

View File

@ -1,5 +1,7 @@
package net.lax1dude.eaglercraft.v1_8.internal; package net.lax1dude.eaglercraft.v1_8.internal;
import java.util.function.Consumer;
/** /**
* Copyright (c) 2024 lax1dude. All Rights Reserved. * Copyright (c) 2024 lax1dude. All Rights Reserved.
* *
@ -28,4 +30,6 @@ public interface IClientConfigAdapterHooks {
String callLocalStorageLoadHook(String key); String callLocalStorageLoadHook(String key);
void callCrashReportHook(String crashReport, Consumer<String> customMessageCB);
} }

View File

@ -77,7 +77,7 @@ public class AcceleratedEffectRenderer implements IAcceleratedParticleEngine {
int lightMapData, int texSize, float particleSize, float r, float g, float b, float a) { int lightMapData, int texSize, float particleSize, float r, float g, float b, float a) {
if (!Config.renderParticles()) return; if (!Config.renderParticles()) return;
InstancedParticleRenderer.appendParticle(posX, posY, posZ, particleIndexX, particleIndexY, lightMapData & 0xFF, InstancedParticleRenderer.appendParticle(posX, posY, posZ, particleIndexX, particleIndexY, lightMapData & 0xFF,
(lightMapData >> 16) & 0xFF, (int)(particleSize * 16.0f), texSize, r, g, b, a); (lightMapData >>> 16) & 0xFF, (int)(particleSize * 16.0f), texSize, r, g, b, a);
} }
@Override @Override
@ -85,7 +85,7 @@ public class AcceleratedEffectRenderer implements IAcceleratedParticleEngine {
int lightMapData, int texSize, float particleSize, int rgba) { int lightMapData, int texSize, float particleSize, int rgba) {
if (!Config.renderParticles()) return; if (!Config.renderParticles()) return;
InstancedParticleRenderer.appendParticle(posX, posY, posZ, particleIndexX, particleIndexY, lightMapData & 0xFF, InstancedParticleRenderer.appendParticle(posX, posY, posZ, particleIndexX, particleIndexY, lightMapData & 0xFF,
(lightMapData >> 16) & 0xFF, (int)(particleSize * 16.0f), texSize, rgba); (lightMapData >>> 16) & 0xFF, (int)(particleSize * 16.0f), texSize, rgba);
} }
} }

View File

@ -47,10 +47,10 @@ public class EaglerFontRenderer extends FontRenderer {
if ((color & 0xFC000000) == 0) { if ((color & 0xFC000000) == 0) {
color |= 0xFF000000; color |= 0xFF000000;
} }
this.red = (float) (color >> 16 & 255) / 255.0F; this.red = (float) (color >>> 16 & 255) / 255.0F;
this.blue = (float) (color >> 8 & 255) / 255.0F; this.blue = (float) (color >>> 8 & 255) / 255.0F;
this.green = (float) (color & 255) / 255.0F; this.green = (float) (color & 255) / 255.0F;
this.alpha = (float) (color >> 24 & 255) / 255.0F; this.alpha = (float) (color >>> 24 & 255) / 255.0F;
this.posX = x; this.posX = x;
this.posY = y; this.posY = y;
this.textColor = color; this.textColor = color;

View File

@ -72,8 +72,8 @@ public class ByteBufEaglercraftImpl extends AbstractByteBuf {
@Override @Override
protected void _setMedium(int index, int value) { protected void _setMedium(int index, int value) {
internal.put(index, (byte)((value >> 16) & 0xFF)); internal.put(index, (byte)((value >>> 16) & 0xFF));
internal.put(index + 1, (byte)((value >> 8) & 0xFF)); internal.put(index + 1, (byte)((value >>> 8) & 0xFF));
internal.put(index + 2, (byte)(value & 0xFF)); internal.put(index + 2, (byte)(value & 0xFF));
} }

View File

@ -118,14 +118,14 @@ public class ImageData {
if((spx & 0xFF000000) == 0xFF000000 || (dpx & 0xFF000000) == 0) { if((spx & 0xFF000000) == 0xFF000000 || (dpx & 0xFF000000) == 0) {
pixels[di] = spx; pixels[di] = spx;
}else { }else {
int sa = (spx >> 24) & 0xFF; int sa = (spx >>> 24) & 0xFF;
int da = (dpx >> 24) & 0xFF; int da = (dpx >>> 24) & 0xFF;
int r = ((spx >> 16) & 0xFF) * sa / 255; int r = ((spx >>> 16) & 0xFF) * sa / 255;
int g = ((spx >> 8) & 0xFF) * sa / 255; int g = ((spx >>> 8) & 0xFF) * sa / 255;
int b = (spx & 0xFF) * sa / 255; int b = (spx & 0xFF) * sa / 255;
int aa = (255 - sa) * da; int aa = (255 - sa) * da;
r += ((dpx >> 16) & 0xFF) * aa / 65025; r += ((dpx >>> 16) & 0xFF) * aa / 65025;
g += ((dpx >> 8) & 0xFF) * aa / 65025; g += ((dpx >>> 8) & 0xFF) * aa / 65025;
b += (dpx & 0xFF) * aa / 65025; b += (dpx & 0xFF) * aa / 65025;
sa += da; sa += da;
if(sa > 0xFF) sa = 0xFF; if(sa > 0xFF) sa = 0xFF;
@ -138,14 +138,14 @@ public class ImageData {
public ImageData swapRB() { public ImageData swapRB() {
for(int i = 0; i < pixels.length; ++i) { for(int i = 0; i < pixels.length; ++i) {
int j = pixels[i]; int j = pixels[i];
pixels[i] = (j & 0xFF00FF00) | ((j & 0x00FF0000) >> 16) | pixels[i] = (j & 0xFF00FF00) | ((j & 0x00FF0000) >>> 16) |
((j & 0x000000FF) << 16); ((j & 0x000000FF) << 16);
} }
return this; return this;
} }
public static int swapRB(int c) { public static int swapRB(int c) {
return (c & 0xFF00FF00) | ((c & 0x00FF0000) >> 16) | ((c & 0x000000FF) << 16); return (c & 0xFF00FF00) | ((c & 0x00FF0000) >>> 16) | ((c & 0x000000FF) << 16);
} }
} }

View File

@ -413,7 +413,7 @@ public class InstancedFontRenderer {
buf.putShort((short)y); buf.putShort((short)y);
buf.put((byte)cx); buf.put((byte)cx);
buf.put((byte)cy); buf.put((byte)cy);
color = ((color >> 1) & 0x7F000000) | (color & 0xFFFFFF); color = ((color >>> 1) & 0x7F000000) | (color & 0xFFFFFF);
if(italic) { if(italic) {
color |= 0x80000000; color |= 0x80000000;
} }
@ -438,7 +438,7 @@ public class InstancedFontRenderer {
buf.putShort((short)y); buf.putShort((short)y);
buf.put((byte)cx); buf.put((byte)cx);
buf.put((byte)cy); buf.put((byte)cy);
color = ((color >> 1) & 0x7F000000) | (color & 0xFFFFFF); color = ((color >>> 1) & 0x7F000000) | (color & 0xFFFFFF);
if(italic) { if(italic) {
color |= 0x80000000; color |= 0x80000000;
} }

View File

@ -275,8 +275,8 @@ public class WorldRenderer {
if (!this.needsUpdate) { if (!this.needsUpdate) {
j = this.intBuffer.get(i); j = this.intBuffer.get(i);
int k = (int) ((float) (j & 255) * red); int k = (int) ((float) (j & 255) * red);
int l = (int) ((float) (j >> 8 & 255) * green); int l = (int) ((float) (j >>> 8 & 255) * green);
int i1 = (int) ((float) (j >> 16 & 255) * blue); int i1 = (int) ((float) (j >>> 16 & 255) * blue);
j = j & -16777216; j = j & -16777216;
j = j | i1 << 16 | l << 8 | k; j = j | i1 << 16 | l << 8 | k;
} }
@ -288,10 +288,10 @@ public class WorldRenderer {
*/ */
private void putColor(int argb, int parInt2) { private void putColor(int argb, int parInt2) {
int i = this.getColorIndex(parInt2); int i = this.getColorIndex(parInt2);
int j = argb >> 16 & 255; int j = argb >>> 16 & 255;
int k = argb >> 8 & 255; int k = argb >>> 8 & 255;
int l = argb & 255; int l = argb & 255;
int i1 = argb >> 24 & 255; int i1 = argb >>> 24 & 255;
this.putColorRGBA(i, j, k, l, i1); this.putColorRGBA(i, j, k, l, i1);
} }

View File

@ -63,8 +63,8 @@ public class CapePackets {
} }
public static byte[] writeMyCapePreset(int capeId) { public static byte[] writeMyCapePreset(int capeId) {
return new byte[] { (byte) PACKET_MY_CAPE_PRESET, (byte) (capeId >> 24), (byte) (capeId >> 16), return new byte[] { (byte) PACKET_MY_CAPE_PRESET, (byte) (capeId >>> 24), (byte) (capeId >>> 16),
(byte) (capeId >> 8), (byte) (capeId & 0xFF) }; (byte) (capeId >>> 8), (byte) (capeId & 0xFF) };
} }
public static byte[] writeMyCapeCustom(CustomCape customCape) { public static byte[] writeMyCapeCustom(CustomCape customCape) {

View File

@ -39,9 +39,14 @@ public enum DefaultCapes {
SNOWMAN(17, "Snowman", new ResourceLocation("eagler:capes/17.snowman.png")), SNOWMAN(17, "Snowman", new ResourceLocation("eagler:capes/17.snowman.png")),
SPADE(18, "Spade", new ResourceLocation("eagler:capes/18.spade.png")), SPADE(18, "Spade", new ResourceLocation("eagler:capes/18.spade.png")),
BIRTHDAY(19, "Birthday", new ResourceLocation("eagler:capes/19.birthday.png")), BIRTHDAY(19, "Birthday", new ResourceLocation("eagler:capes/19.birthday.png")),
DB(20, "dB", new ResourceLocation("eagler:capes/20.db.png")); DB(20, "dB", new ResourceLocation("eagler:capes/20.db.png")),
_15TH_ANNIVERSARY(21, "15th Anniversary", new ResourceLocation("eagler:capes/21.15th_anniversary.png")),
VANILLA(22, "Vanilla", new ResourceLocation("eagler:capes/22.vanilla.png")),
TIKTOK(23, "TikTok", new ResourceLocation("eagler:capes/23.tiktok.png")),
PURPLE_HEART(24, "Purple Heart", new ResourceLocation("eagler:capes/24.purple_heart.png")),
CHERRY_BLOSSOM(25, "Cherry Blossom", new ResourceLocation("eagler:capes/25.cherry_blossom.png"));
public static final DefaultCapes[] defaultCapesMap = new DefaultCapes[21]; public static final DefaultCapes[] defaultCapesMap = new DefaultCapes[26];
public final int id; public final int id;
public final String name; public final String name;

View File

@ -363,9 +363,9 @@ public class GuiScreenEditProfile extends GuiScreen {
for (int i = 0, j, k; i < 4096; ++i) { for (int i = 0, j, k; i < 4096; ++i) {
j = i << 2; j = i << 2;
k = loadedSkin.pixels[i]; k = loadedSkin.pixels[i];
rawSkin[j] = (byte) (k >> 24); rawSkin[j] = (byte)(k >>> 24);
rawSkin[j + 1] = (byte) (k >> 16); rawSkin[j + 1] = (byte)(k >>> 16);
rawSkin[j + 2] = (byte) (k >> 8); rawSkin[j + 2] = (byte)(k >>> 8);
rawSkin[j + 3] = (byte)(k & 0xFF); rawSkin[j + 3] = (byte)(k & 0xFF);
} }
for (int y = 20; y < 32; ++y) { for (int y = 20; y < 32; ++y) {

View File

@ -68,7 +68,7 @@ public class ProfileExporter {
+ (doExportServers ? "servers " : "") + (doExportResourcePacks ? "resourcePacks" : "") + "\n\n") + (doExportServers ? "servers " : "") + (doExportResourcePacks ? "resourcePacks" : "") + "\n\n")
.getBytes(StandardCharsets.UTF_8); .getBytes(StandardCharsets.UTF_8);
osb.write((comment.length >> 8) & 255); osb.write((comment.length >>> 8) & 255);
osb.write(comment.length & 255); osb.write(comment.length & 255);
osb.write(comment); osb.write(comment);
@ -181,9 +181,9 @@ public class ProfileExporter {
byte[] ret = osb.toByteArray(); byte[] ret = osb.toByteArray();
ret[lengthIntegerOffset] = (byte) ((fileCount >> 24) & 0xFF); ret[lengthIntegerOffset] = (byte)((fileCount >>> 24) & 0xFF);
ret[lengthIntegerOffset + 1] = (byte) ((fileCount >> 16) & 0xFF); ret[lengthIntegerOffset + 1] = (byte)((fileCount >>> 16) & 0xFF);
ret[lengthIntegerOffset + 2] = (byte) ((fileCount >> 8) & 0xFF); ret[lengthIntegerOffset + 2] = (byte)((fileCount >>> 8) & 0xFF);
ret[lengthIntegerOffset + 3] = (byte)(fileCount & 0xFF); ret[lengthIntegerOffset + 3] = (byte)(fileCount & 0xFF);
logger.info("Export complete!"); logger.info("Export complete!");

View File

@ -50,8 +50,8 @@ public class SkinConverter {
i = (y * 23 + x) * 3; i = (y * 23 + x) * 3;
j = skinIn.pixels[y * skinIn.width + x]; j = skinIn.pixels[y * skinIn.width + x];
if((j & 0xFF000000) != 0) { if((j & 0xFF000000) != 0) {
skinOut[i] = (byte) (j >> 16); skinOut[i] = (byte)(j >>> 16);
skinOut[i + 1] = (byte) (j >> 8); skinOut[i + 1] = (byte)(j >>> 8);
skinOut[i + 2] = (byte)(j & 0xFF); skinOut[i + 2] = (byte)(j & 0xFF);
}else { }else {
skinOut[i] = skinOut[i + 1] = skinOut[i + 2] = 0; skinOut[i] = skinOut[i + 1] = skinOut[i + 2] = 0;
@ -62,8 +62,8 @@ public class SkinConverter {
i = ((y + 6) * 23 + 22) * 3; i = ((y + 6) * 23 + 22) * 3;
j = skinIn.pixels[(y + 11) * skinIn.width + 22]; j = skinIn.pixels[(y + 11) * skinIn.width + 22];
if((j & 0xFF000000) != 0) { if((j & 0xFF000000) != 0) {
skinOut[i] = (byte) (j >> 16); skinOut[i] = (byte)(j >>> 16);
skinOut[i + 1] = (byte) (j >> 8); skinOut[i + 1] = (byte)(j >>> 8);
skinOut[i + 2] = (byte)(j & 0xFF); skinOut[i + 2] = (byte)(j & 0xFF);
}else { }else {
skinOut[i] = skinOut[i + 1] = skinOut[i + 2] = 0; skinOut[i] = skinOut[i + 1] = skinOut[i + 2] = 0;

View File

@ -91,8 +91,8 @@ public class SkinPackets {
} }
public static byte[] writeMySkinPreset(int skinId) { public static byte[] writeMySkinPreset(int skinId) {
return new byte[] { (byte) PACKET_MY_SKIN_PRESET, (byte) (skinId >> 24), (byte) (skinId >> 16), return new byte[] { (byte) PACKET_MY_SKIN_PRESET, (byte) (skinId >>> 24), (byte) (skinId >>> 16),
(byte) (skinId >> 8), (byte) (skinId & 0xFF) }; (byte) (skinId >>> 8), (byte) (skinId & 0xFF) };
} }
public static byte[] writeMySkinCustom(CustomSkin customSkin) { public static byte[] writeMySkinCustom(CustomSkin customSkin) {

View File

@ -206,12 +206,12 @@ public class ConnectionHandshake {
int passLen = password.length(); int passLen = password.length();
digest.update((byte) ((passLen >> 8) & 0xFF)); digest.update((byte)((passLen >>> 8) & 0xFF));
digest.update((byte)(passLen & 0xFF)); digest.update((byte)(passLen & 0xFF));
for(int i = 0; i < passLen; ++i) { for(int i = 0; i < passLen; ++i) {
char codePoint = password.charAt(i); char codePoint = password.charAt(i);
digest.update((byte) ((codePoint >> 8) & 0xFF)); digest.update((byte)((codePoint >>> 8) & 0xFF));
digest.update((byte)(codePoint & 0xFF)); digest.update((byte)(codePoint & 0xFF));
} }

View File

@ -57,9 +57,9 @@ public class SkullCommand {
for(int i = 0, j, k; i < 4096; ++i) { for(int i = 0, j, k; i < 4096; ++i) {
j = i << 2; j = i << 2;
k = loaded.pixels[i]; k = loaded.pixels[i];
rawSkin[j] = (byte)(k >> 24); rawSkin[j] = (byte)(k >>> 24);
rawSkin[j + 1] = (byte)(k >> 16); rawSkin[j + 1] = (byte)(k >>> 16);
rawSkin[j + 2] = (byte)(k >> 8); rawSkin[j + 2] = (byte)(k >>> 8);
rawSkin[j + 3] = (byte)(k & 0xFF); rawSkin[j + 3] = (byte)(k & 0xFF);
} }
mc.thePlayer.sendQueue.addToSendQueue(new C17PacketCustomPayload("EAG|Skins-1.8", SkinPackets.writeCreateCustomSkull(rawSkin))); mc.thePlayer.sendQueue.addToSendQueue(new C17PacketCustomPayload("EAG|Skins-1.8", SkinPackets.writeCreateCustomSkull(rawSkin)));

View File

@ -8,8 +8,10 @@ import net.lax1dude.eaglercraft.v1_8.sp.relay.RelayServer;
import net.lax1dude.eaglercraft.v1_8.sp.relay.RelayServerSocket; import net.lax1dude.eaglercraft.v1_8.sp.relay.RelayServerSocket;
import net.lax1dude.eaglercraft.v1_8.sp.socket.NetHandlerSingleplayerLogin; import net.lax1dude.eaglercraft.v1_8.sp.socket.NetHandlerSingleplayerLogin;
import net.minecraft.client.LoadingScreenRenderer; import net.minecraft.client.LoadingScreenRenderer;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.GuiDisconnected; import net.minecraft.client.gui.GuiDisconnected;
import net.minecraft.client.gui.GuiScreen; import net.minecraft.client.gui.GuiScreen;
import net.minecraft.client.multiplayer.ServerData;
import net.minecraft.client.resources.I18n; import net.minecraft.client.resources.I18n;
import net.minecraft.network.EnumConnectionState; import net.minecraft.network.EnumConnectionState;
import net.minecraft.network.login.client.C00PacketLoginStart; import net.minecraft.network.login.client.C00PacketLoginStart;
@ -62,6 +64,7 @@ public class GuiScreenLANConnecting extends GuiScreen {
this.parent = parent; this.parent = parent;
this.code = code; this.code = code;
this.relay = relay; this.relay = relay;
Minecraft.getMinecraft().setServerData(new ServerData("Shared World", "shared:" + relay.address, false));
} }
public boolean doesGuiPauseGame() { public boolean doesGuiPauseGame() {

View File

@ -40,7 +40,7 @@ import net.lax1dude.eaglercraft.v1_8.sp.relay.pkt.*;
*/ */
public class LANServerController { public class LANServerController {
public static final Logger logger = LogManager.getLogger("IntegratedServerLAN"); public static final Logger logger = LogManager.getLogger("LANServerController");
public static final List<String> currentICEServers = new ArrayList(); public static final List<String> currentICEServers = new ArrayList();

View File

@ -154,7 +154,7 @@ public class IPacket {
is.write(0); is.write(0);
}else { }else {
int l = txt.length(); int l = txt.length();
is.write((l >> 8) & 0xFF); is.write((l >>> 8) & 0xFF);
is.write(l & 0xFF); is.write(l & 0xFF);
for(int i = 0; i < l; ++i) { for(int i = 0; i < l; ++i) {
is.write((int)txt.charAt(i)); is.write((int)txt.charAt(i));

View File

@ -42,8 +42,8 @@ public class EaglerChunkLoader extends AnvilChunkLoader {
char[] path = new char[12]; char[] path = new char[12];
for(int i = 5; i >= 0; --i) { for(int i = 5; i >= 0; --i) {
path[i] = hex.charAt((unsignedX >> (i * 4)) & 0xF); path[i] = hex.charAt((unsignedX >>> (i << 2)) & 0xF);
path[i + 6] = hex.charAt((unsignedZ >> (i * 4)) & 0xF); path[i + 6] = hex.charAt((unsignedZ >>> (i << 2)) & 0xF);
} }
return new String(path); return new String(path);

View File

@ -49,7 +49,7 @@ public class EPKCompiler {
EagRuntime.fixDateFormat(new SimpleDateFormat("hh:mm:ss aa")).format(d) + "\n\n # world name: " + name + "\n\n") EagRuntime.fixDateFormat(new SimpleDateFormat("hh:mm:ss aa")).format(d) + "\n\n # world name: " + name + "\n\n")
.getBytes(StandardCharsets.UTF_8); .getBytes(StandardCharsets.UTF_8);
os.write((comment.length >> 8) & 255); os.write((comment.length >>> 8) & 255);
os.write(comment.length & 255); os.write(comment.length & 255);
os.write(comment); os.write(comment);
@ -134,9 +134,9 @@ public class EPKCompiler {
byte[] ret = os.toByteArray(); byte[] ret = os.toByteArray();
ret[lengthIntegerOffset] = (byte)((totalFileCount >> 24) & 0xFF); ret[lengthIntegerOffset] = (byte)(totalFileCount >>> 24);
ret[lengthIntegerOffset + 1] = (byte)((totalFileCount >> 16) & 0xFF); ret[lengthIntegerOffset + 1] = (byte)(totalFileCount >>> 16);
ret[lengthIntegerOffset + 2] = (byte)((totalFileCount >> 8) & 0xFF); ret[lengthIntegerOffset + 2] = (byte)(totalFileCount >>> 8);
ret[lengthIntegerOffset + 3] = (byte)(totalFileCount & 0xFF); ret[lengthIntegerOffset + 3] = (byte)(totalFileCount & 0xFF);
return ret; return ret;
@ -147,21 +147,21 @@ public class EPKCompiler {
} }
public static void writeInt(int i, OutputStream os) throws IOException { public static void writeInt(int i, OutputStream os) throws IOException {
os.write((i >> 24) & 0xFF); os.write((i >>> 24) & 0xFF);
os.write((i >> 16) & 0xFF); os.write((i >>> 16) & 0xFF);
os.write((i >> 8) & 0xFF); os.write((i >>> 8) & 0xFF);
os.write(i & 0xFF); os.write(i & 0xFF);
} }
public static void writeLong(long i, OutputStream os) throws IOException { public static void writeLong(long i, OutputStream os) throws IOException {
os.write((int)((i >> 56) & 0xFF)); os.write((int)((i >>> 56l) & 0xFFl));
os.write((int)((i >> 48) & 0xFF)); os.write((int)((i >>> 48l) & 0xFFl));
os.write((int)((i >> 40) & 0xFF)); os.write((int)((i >>> 40l) & 0xFFl));
os.write((int)((i >> 32) & 0xFF)); os.write((int)((i >>> 32l) & 0xFFl));
os.write((int)((i >> 24) & 0xFF)); os.write((int)((i >>> 24l) & 0xFFl));
os.write((int)((i >> 16) & 0xFF)); os.write((int)((i >>> 16l) & 0xFFl));
os.write((int)((i >> 8) & 0xFF)); os.write((int)((i >>> 8l) & 0xFFl));
os.write((int)(i & 0xFF)); os.write((int)(i & 0xFFl));
} }
} }

View File

@ -89,9 +89,9 @@ public class IntegratedCapePackets {
byte[] ret = new byte[1 + 16 + 4]; byte[] ret = new byte[1 + 16 + 4];
ret[0] = (byte)PACKET_OTHER_CAPE_PRESET; ret[0] = (byte)PACKET_OTHER_CAPE_PRESET;
IntegratedSkinPackets.UUIDToBytes(uuid, ret, 1); IntegratedSkinPackets.UUIDToBytes(uuid, ret, 1);
ret[17] = (byte)(presetId >> 24); ret[17] = (byte)(presetId >>> 24);
ret[18] = (byte)(presetId >> 16); ret[18] = (byte)(presetId >>> 16);
ret[19] = (byte)(presetId >> 8); ret[19] = (byte)(presetId >>> 8);
ret[20] = (byte)(presetId & 0xFF); ret[20] = (byte)(presetId & 0xFF);
return ret; return ret;
} }

View File

@ -143,9 +143,9 @@ public class IntegratedSkinPackets {
byte[] ret = new byte[1 + 16 + 4]; byte[] ret = new byte[1 + 16 + 4];
ret[0] = (byte)PACKET_OTHER_SKIN_PRESET; ret[0] = (byte)PACKET_OTHER_SKIN_PRESET;
UUIDToBytes(uuid, ret, 1); UUIDToBytes(uuid, ret, 1);
ret[17] = (byte)(presetId >> 24); ret[17] = (byte)(presetId >>> 24);
ret[18] = (byte)(presetId >> 16); ret[18] = (byte)(presetId >>> 16);
ret[19] = (byte)(presetId >> 8); ret[19] = (byte)(presetId >>> 8);
ret[20] = (byte)(presetId & 0xFF); ret[20] = (byte)(presetId & 0xFF);
return ret; return ret;
} }
@ -197,21 +197,21 @@ public class IntegratedSkinPackets {
public static void UUIDToBytes(EaglercraftUUID uuid, byte[] bytes, int off) { public static void UUIDToBytes(EaglercraftUUID uuid, byte[] bytes, int off) {
long msb = uuid.getMostSignificantBits(); long msb = uuid.getMostSignificantBits();
long lsb = uuid.getLeastSignificantBits(); long lsb = uuid.getLeastSignificantBits();
bytes[off] = (byte)(msb >> 56l); bytes[off] = (byte)(msb >>> 56l);
bytes[off + 1] = (byte)(msb >> 48l); bytes[off + 1] = (byte)(msb >>> 48l);
bytes[off + 2] = (byte)(msb >> 40l); bytes[off + 2] = (byte)(msb >>> 40l);
bytes[off + 3] = (byte)(msb >> 32l); bytes[off + 3] = (byte)(msb >>> 32l);
bytes[off + 4] = (byte)(msb >> 24l); bytes[off + 4] = (byte)(msb >>> 24l);
bytes[off + 5] = (byte)(msb >> 16l); bytes[off + 5] = (byte)(msb >>> 16l);
bytes[off + 6] = (byte)(msb >> 8l); bytes[off + 6] = (byte)(msb >>> 8l);
bytes[off + 7] = (byte)(msb & 0xFFl); bytes[off + 7] = (byte)(msb & 0xFFl);
bytes[off + 8] = (byte)(lsb >> 56l); bytes[off + 8] = (byte)(lsb >>> 56l);
bytes[off + 9] = (byte)(lsb >> 48l); bytes[off + 9] = (byte)(lsb >>> 48l);
bytes[off + 10] = (byte)(lsb >> 40l); bytes[off + 10] = (byte)(lsb >>> 40l);
bytes[off + 11] = (byte)(lsb >> 32l); bytes[off + 11] = (byte)(lsb >>> 32l);
bytes[off + 12] = (byte)(lsb >> 24l); bytes[off + 12] = (byte)(lsb >>> 24l);
bytes[off + 13] = (byte)(lsb >> 16l); bytes[off + 13] = (byte)(lsb >>> 16l);
bytes[off + 14] = (byte)(lsb >> 8l); bytes[off + 14] = (byte)(lsb >>> 8l);
bytes[off + 15] = (byte)(lsb & 0xFFl); bytes[off + 15] = (byte)(lsb & 0xFFl);
} }

View File

@ -253,9 +253,9 @@ public class IntegratedServerPlayerNetworkManager {
byte[] compressedData; byte[] compressedData;
try { try {
temporaryOutputStream.write(2); temporaryOutputStream.write(2);
temporaryOutputStream.write((len >> 24) & 0xFF); temporaryOutputStream.write((len >>> 24) & 0xFF);
temporaryOutputStream.write((len >> 16) & 0xFF); temporaryOutputStream.write((len >>> 16) & 0xFF);
temporaryOutputStream.write((len >> 8) & 0xFF); temporaryOutputStream.write((len >>> 8) & 0xFF);
temporaryOutputStream.write(len & 0xFF); temporaryOutputStream.write(len & 0xFF);
try (OutputStream os = EaglerZLIB.newDeflaterOutputStream(temporaryOutputStream)) { try (OutputStream os = EaglerZLIB.newDeflaterOutputStream(temporaryOutputStream)) {
temporaryBuffer.readBytes(os, len); temporaryBuffer.readBytes(os, len);

View File

@ -127,13 +127,13 @@ public class GuiUpdateVersionSlot extends GuiSlot {
if(strs.size() > 2 && screen.mx > xx + iconSize && screen.my > yy + 8 && screen.mx < xx + getListWidth() - 5 && screen.my < yy + 25) { if(strs.size() > 2 && screen.mx > xx + iconSize && screen.my > yy + 8 && screen.mx < xx + getListWidth() - 5 && screen.my < yy + 25) {
screen.tooltip = cert.bundleVersionComment; screen.tooltip = cert.bundleVersionComment;
} }
char[] hexStr1 = new char[] { hexChars[(cert.bundleDataHash[0] >> 4) & 0xF], char[] hexStr1 = new char[] { hexChars[(cert.bundleDataHash[0] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[1] & 0xF], hexChars[(cert.bundleDataHash[1] >> 4) & 0xF], hexChars[cert.bundleDataHash[1] & 0xF], hexChars[(cert.bundleDataHash[1] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[1] & 0xF], hexChars[(cert.bundleDataHash[2] >> 4) & 0xF], hexChars[cert.bundleDataHash[1] & 0xF], hexChars[(cert.bundleDataHash[2] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[2] & 0xF] }; hexChars[cert.bundleDataHash[2] & 0xF] };
char[] hexStr2 = new char[] { hexChars[(cert.bundleDataHash[29] >> 4) & 0xF], char[] hexStr2 = new char[] { hexChars[(cert.bundleDataHash[29] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[29] & 0xF], hexChars[(cert.bundleDataHash[30] >> 4) & 0xF], hexChars[cert.bundleDataHash[29] & 0xF], hexChars[(cert.bundleDataHash[30] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[30] & 0xF], hexChars[(cert.bundleDataHash[31] >> 4) & 0xF], hexChars[cert.bundleDataHash[30] & 0xF], hexChars[(cert.bundleDataHash[31] >>> 4) & 0xF],
hexChars[cert.bundleDataHash[31] & 0xF] }; hexChars[cert.bundleDataHash[31] & 0xF] };
screen.drawString(mc.fontRendererObj, screen.drawString(mc.fontRendererObj,
"Author: " + EnumChatFormatting.GRAY + cert.bundleAuthorName + EnumChatFormatting.WHITE + " Hash: " "Author: " + EnumChatFormatting.GRAY + cert.bundleAuthorName + EnumChatFormatting.WHITE + " Hash: "

View File

@ -153,12 +153,11 @@ public class UpdateCertificate {
sha256.update(signaturePayload, 0, signaturePayload.length); sha256.update(signaturePayload, 0, signaturePayload.length);
sha256.doFinal(hash2048, 96); sha256.doFinal(hash2048, 96);
hash2048[0] = (byte) ((signaturePayload.length >> 8) & 0xFF); hash2048[0] = (byte)((signaturePayload.length >>> 8) & 0xFF);
hash2048[1] = (byte)(signaturePayload.length & 0xFF); hash2048[1] = (byte)(signaturePayload.length & 0xFF);
if(!Arrays.equals(hash2048, rsa2048sumDec)) { if(!Arrays.equals(hash2048, rsa2048sumDec)) {
UpdateService.logger.error("SHA256 checksum of signature payload is invalid!"); throw new CertificateInvalidException("SHA256 checksum of signature payload is invalid!");
return null;
} }
UpdateCertificate cert; UpdateCertificate cert;

View File

@ -615,9 +615,9 @@ public class GuiVoiceMenu extends Gui {
} }
public static int attenuate(int cin, float r, float g, float b, float a) { public static int attenuate(int cin, float r, float g, float b, float a) {
float var10 = (float) (cin >> 24 & 255) / 255.0F; float var10 = (float) (cin >>> 24 & 255) / 255.0F;
float var6 = (float) (cin >> 16 & 255) / 255.0F; float var6 = (float) (cin >>> 16 & 255) / 255.0F;
float var7 = (float) (cin >> 8 & 255) / 255.0F; float var7 = (float) (cin >>> 8 & 255) / 255.0F;
float var8 = (float) (cin & 255) / 255.0F; float var8 = (float) (cin & 255) / 255.0F;
var10 *= a; var10 *= a;
var6 *= r; var6 *= r;

View File

@ -1827,6 +1827,7 @@ public class Minecraft implements IThreadListener {
session.reset(); session.reset();
SingleplayerServerController.launchEaglercraftServer(folderName, gameSettings.difficulty.getDifficultyId(), SingleplayerServerController.launchEaglercraftServer(folderName, gameSettings.difficulty.getDifficultyId(),
Math.max(gameSettings.renderDistanceChunks, 2), worldSettingsIn); Math.max(gameSettings.renderDistanceChunks, 2), worldSettingsIn);
EagRuntime.setMCServerWindowGlobal("singleplayer");
this.displayGuiScreen(new GuiScreenIntegratedServerBusy( this.displayGuiScreen(new GuiScreenIntegratedServerBusy(
new GuiScreenSingleplayerConnecting(new GuiMainMenu(), "Connecting to " + folderName), new GuiScreenSingleplayerConnecting(new GuiMainMenu(), "Connecting to " + folderName),
"singleplayer.busy.startingIntegratedServer", "singleplayer.failed.startingIntegratedServer", "singleplayer.busy.startingIntegratedServer", "singleplayer.failed.startingIntegratedServer",
@ -2115,6 +2116,22 @@ public class Minecraft implements IThreadListener {
+ EaglercraftGPU.glGetString(7936); + EaglercraftGPU.glGetString(7936);
} }
}); });
theCrash.getCategory().addCrashSectionCallable("Is Eagler Shaders", new Callable<String>() {
public String call() throws Exception {
return Minecraft.this.gameSettings.shaders ? "Yes" : "No";
}
});
theCrash.getCategory().addCrashSectionCallable("Is Dynamic Lights", new Callable<String>() {
public String call() throws Exception {
return !Minecraft.this.gameSettings.shaders && Minecraft.this.gameSettings.enableDynamicLights ? "Yes"
: "No";
}
});
theCrash.getCategory().addCrashSectionCallable("In Ext. Pipeline", new Callable<String>() {
public String call() throws Exception {
return GlStateManager.isExtensionPipeline() ? "Yes" : "No";
}
});
theCrash.getCategory().addCrashSectionCallable("Is Modded", new Callable<String>() { theCrash.getCategory().addCrashSectionCallable("Is Modded", new Callable<String>() {
public String call() throws Exception { public String call() throws Exception {
return "Definitely Not; You're an eagler"; return "Definitely Not; You're an eagler";
@ -2197,6 +2214,7 @@ public class Minecraft implements IThreadListener {
*/ */
public void setServerData(ServerData serverDataIn) { public void setServerData(ServerData serverDataIn) {
this.currentServerData = serverDataIn; this.currentServerData = serverDataIn;
EagRuntime.setMCServerWindowGlobal(serverDataIn != null ? serverDataIn.serverIP : null);
} }
public ServerData getCurrentServerData() { public ServerData getCurrentServerData() {

View File

@ -598,8 +598,10 @@ public class GuiMainMenu extends GuiScreen implements GuiYesNoCallback {
short short1 = 274; short short1 = 274;
int k = this.width / 2 - short1 / 2; int k = this.width / 2 - short1 / 2;
byte b0 = 30; byte b0 = 30;
if (enableBlur) {
this.drawGradientRect(0, 0, this.width, this.height, -2130706433, 16777215); this.drawGradientRect(0, 0, this.width, this.height, -2130706433, 16777215);
this.drawGradientRect(0, 0, this.width, this.height, 0, Integer.MIN_VALUE); this.drawGradientRect(0, 0, this.width, this.height, 0, Integer.MIN_VALUE);
}
this.mc.getTextureManager().bindTexture(minecraftTitleTextures); this.mc.getTextureManager().bindTexture(minecraftTitleTextures);
GlStateManager.color(1.0F, 1.0F, 1.0F, 1.0F); GlStateManager.color(1.0F, 1.0F, 1.0F, 1.0F);
boolean minc = (double) this.updateCounter < 1.0E-4D; boolean minc = (double) this.updateCounter < 1.0E-4D;

View File

@ -129,7 +129,7 @@ public class MapItemRenderer {
} else { } else {
c = MapColor.mapColorArray[j / 4].func_151643_b(j & 3); c = MapColor.mapColorArray[j / 4].func_151643_b(j & 3);
} }
this.mapTextureData[i] = (c & 0xFF00FF00) | ((c & 0x00FF0000) >> 16) | ((c & 0x000000FF) << 16); this.mapTextureData[i] = (c & 0xFF00FF00) | ((c & 0x00FF0000) >>> 16) | ((c & 0x000000FF) << 16);
} }
this.mapTexture.updateDynamicTexture(); this.mapTexture.updateDynamicTexture();

View File

@ -366,9 +366,9 @@ public abstract class RendererLivingEntity<T extends EntityLivingBase> extends R
return false; return false;
} else { } else {
GlStateManager.enableShaderBlendAdd(); GlStateManager.enableShaderBlendAdd();
float f1 = 1.0F - (float) (i >> 24 & 255) / 255.0F; float f1 = 1.0F - (float) (i >>> 24 & 255) / 255.0F;
float f2 = (float) (i >> 16 & 255) / 255.0F; float f2 = (float) (i >>> 16 & 255) / 255.0F;
float f3 = (float) (i >> 8 & 255) / 255.0F; float f3 = (float) (i >>> 8 & 255) / 255.0F;
float f4 = (float) (i & 255) / 255.0F; float f4 = (float) (i & 255) / 255.0F;
GlStateManager.setShaderBlendSrc(f1, f1, f1, 1.0F); GlStateManager.setShaderBlendSrc(f1, f1, f1, 1.0F);
GlStateManager.setShaderBlendAdd(f2 * f1 + 0.4F, f3 * f1, f4 * f1, 0.0f); GlStateManager.setShaderBlendAdd(f2 * f1 + 0.4F, f3 * f1, f4 * f1, 0.0f);

View File

@ -320,4 +320,7 @@ public class PlatformApplication {
public static boolean isShowingDebugConsole() { public static boolean isShowingDebugConsole() {
return DebugConsoleWindow.isShowingDebugConsole(); return DebugConsoleWindow.isShowingDebugConsole();
} }
@JSBody(params = { "str" }, script = "window.minecraftServer = str;")
public static native void setMCServerWindowGlobal(String str);
} }

View File

@ -630,6 +630,10 @@ public class PlatformInput {
Window.clearTimeout(mouseUngrabTimeout); Window.clearTimeout(mouseUngrabTimeout);
mouseUngrabTimeout = -1; mouseUngrabTimeout = -1;
} }
try {
win.getDocument().exitPointerLock();
}catch(Throwable t) {
}
} }
public static void pressAnyKeyScreen() { public static void pressAnyKeyScreen() {

View File

@ -94,6 +94,7 @@ public class PlatformRuntime {
win = Window.current(); win = Window.current();
doc = win.getDocument(); doc = win.getDocument();
DebugConsoleWindow.initialize(win); DebugConsoleWindow.initialize(win);
PlatformApplication.setMCServerWindowGlobal(null);
logger.info("Creating main game canvas"); logger.info("Creating main game canvas");

View File

@ -348,11 +348,11 @@ public class EaglerArrayByteBuffer implements ByteBuffer {
@Override @Override
public ByteBuffer putLong(long value) { public ByteBuffer putLong(long value) {
if(position + 8 > limit) throw new ArrayIndexOutOfBoundsException(position); if(position + 8 > limit) throw new ArrayIndexOutOfBoundsException(position);
dataView.setUint32(position, (int) (value & 0xFFFFFFFF), true); dataView.setUint32(position, (int) (value & 0xFFFFFFFFl), true);
dataView.setUint8(position + 4, (short) ((value >> 32) & 0xFF)); dataView.setUint8(position + 4, (short) ((value >>> 32l) & 0xFFl));
dataView.setUint8(position + 5, (short) ((value >> 40) & 0xFF)); dataView.setUint8(position + 5, (short) ((value >>> 40l) & 0xFFl));
dataView.setUint8(position + 6, (short) ((value >> 48) & 0xFF)); dataView.setUint8(position + 6, (short) ((value >>> 48l) & 0xFFl));
dataView.setUint8(position + 7, (short) ((value >> 56) & 0xFF)); dataView.setUint8(position + 7, (short) ((value >>> 56l) & 0xFFl));
position += 8; position += 8;
return this; return this;
} }
@ -368,11 +368,11 @@ public class EaglerArrayByteBuffer implements ByteBuffer {
@Override @Override
public ByteBuffer putLong(int index, long value) { public ByteBuffer putLong(int index, long value) {
if(index + 8 > limit) throw new ArrayIndexOutOfBoundsException(index); if(index + 8 > limit) throw new ArrayIndexOutOfBoundsException(index);
dataView.setUint32(index, (int) (value & 0xFFFFFFFF), true); dataView.setUint32(index, (int) (value & 0xFFFFFFFFl), true);
dataView.setUint8(index + 4, (short) ((value >> 32) & 0xFF)); dataView.setUint8(index + 4, (short) ((value >>> 32l) & 0xFFl));
dataView.setUint8(index + 5, (short) ((value >> 40) & 0xFF)); dataView.setUint8(index + 5, (short) ((value >>> 40l) & 0xFFl));
dataView.setUint8(index + 6, (short) ((value >> 48) & 0xFF)); dataView.setUint8(index + 6, (short) ((value >>> 48l) & 0xFFl));
dataView.setUint8(index + 7, (short) ((value >> 56) & 0xFF)); dataView.setUint8(index + 7, (short) ((value >>> 56l) & 0xFFl));
return this; return this;
} }

View File

@ -3,6 +3,8 @@ package net.lax1dude.eaglercraft.v1_8.internal.teavm;
import java.io.PrintStream; import java.io.PrintStream;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.util.Date; import java.util.Date;
import java.util.LinkedList;
import java.util.List;
import org.json.JSONException; import org.json.JSONException;
import org.teavm.jso.JSBody; import org.teavm.jso.JSBody;
@ -83,6 +85,7 @@ public class ClientMain {
try { try {
JSEaglercraftXOptsRoot eaglercraftOpts = (JSEaglercraftXOptsRoot)opts; JSEaglercraftXOptsRoot eaglercraftOpts = (JSEaglercraftXOptsRoot)opts;
crashOnUncaughtExceptions = eaglercraftOpts.getCrashOnUncaughtExceptions(false);
configRootElementId = eaglercraftOpts.getContainer(); configRootElementId = eaglercraftOpts.getContainer();
if (configRootElementId == null) { if (configRootElementId == null) {
@ -127,6 +130,7 @@ public class ClientMain {
return; return;
} }
if(crashOnUncaughtExceptions) {
systemOut.println("ClientMain: [INFO] registering crash handlers"); systemOut.println("ClientMain: [INFO] registering crash handlers");
setWindowErrorHandler(new WindowErrorHandler() { setWindowErrorHandler(new WindowErrorHandler() {
@ -137,13 +141,11 @@ public class ClientMain {
str.append("Native Browser Exception\n"); str.append("Native Browser Exception\n");
str.append("----------------------------------\n"); str.append("----------------------------------\n");
str.append(" Line: ").append((file == null ? "unknown" : file) + ":" + line + ":" + col) str.append(" Line: ").append((file == null ? "unknown" : file) + ":" + line + ":" + col).append('\n');
.append('\n');
str.append(" Type: ").append(error == null ? "generic" : error.getName()).append('\n'); str.append(" Type: ").append(error == null ? "generic" : error.getName()).append('\n');
if(error != null) { if(error != null) {
str.append(" Desc: ").append(error.getMessage() == null ? "null" : error.getMessage()) str.append(" Desc: ").append(error.getMessage() == null ? "null" : error.getMessage()).append('\n');
.append('\n');
} }
if(message != null) { if(message != null) {
@ -153,13 +155,13 @@ public class ClientMain {
} }
str.append("----------------------------------\n\n"); str.append("----------------------------------\n\n");
str.append(error.getStack() == null ? "No stack trace is available" : error.getStack()) str.append(error.getStack() == null ? "No stack trace is available" : error.getStack()).append('\n');
.append('\n');
showCrashScreen(str.toString()); showCrashScreen(str.toString());
} }
}); });
}
systemOut.println("ClientMain: [INFO] initializing eaglercraftx runtime"); systemOut.println("ClientMain: [INFO] initializing eaglercraftx runtime");
@ -223,6 +225,7 @@ public class ClientMain {
public static HTMLElement configRootElement = null; public static HTMLElement configRootElement = null;
public static EPKFileEntry[] configEPKFiles = null; public static EPKFileEntry[] configEPKFiles = null;
public static String configLocalesFolder = null; public static String configLocalesFolder = null;
public static boolean crashOnUncaughtExceptions = false;
@JSFunctor @JSFunctor
private static interface WindowErrorHandler extends JSObject { private static interface WindowErrorHandler extends JSObject {
@ -247,8 +250,11 @@ public class ClientMain {
private static boolean isCrashed = false; private static boolean isCrashed = false;
public static void showCrashScreen(String t) { public static void showCrashScreen(String t) {
if (!isCrashed) { StringBuilder strBeforeBuilder = new StringBuilder();
isCrashed = true; strBeforeBuilder.append("Game Crashed! I have fallen and I can't get up!\n\n");
strBeforeBuilder.append(t);
strBeforeBuilder.append('\n').append('\n');
String strBefore = strBeforeBuilder.toString();
HTMLDocument doc = Window.current().getDocument(); HTMLDocument doc = Window.current().getDocument();
if(configRootElement == null) { if(configRootElement == null) {
@ -258,9 +264,6 @@ public class ClientMain {
HTMLElement el = configRootElement; HTMLElement el = configRootElement;
StringBuilder str = new StringBuilder(); StringBuilder str = new StringBuilder();
str.append("Game Crashed! I have fallen and I can't get up!\n\n");
str.append(t);
str.append('\n').append('\n');
str.append("eaglercraft.version = \"").append(EaglercraftVersion.projectForkVersion).append("\"\n"); str.append("eaglercraft.version = \"").append(EaglercraftVersion.projectForkVersion).append("\"\n");
str.append("eaglercraft.minecraft = \"1.8.8\"\n"); str.append("eaglercraft.minecraft = \"1.8.8\"\n");
str.append("eaglercraft.brand = \"" + EaglercraftVersion.projectForkVendor + "\"\n"); str.append("eaglercraft.brand = \"" + EaglercraftVersion.projectForkVendor + "\"\n");
@ -272,8 +275,7 @@ public class ClientMain {
str.append(TeaVMClientConfigAdapter.instance.toString()).append('\n'); str.append(TeaVMClientConfigAdapter.instance.toString()).append('\n');
str.append('\n'); str.append('\n');
str.append("currentTime = "); str.append("currentTime = ");
str.append(EagRuntime.fixDateFormat(new SimpleDateFormat("EEE, d MMM yyyy HH:mm:ss Z")).format(new Date())) str.append(EagRuntime.fixDateFormat(new SimpleDateFormat("EEE, d MMM yyyy HH:mm:ss Z")).format(new Date())).append('\n');
.append('\n');
str.append('\n'); str.append('\n');
addDebugNav(str, "userAgent"); addDebugNav(str, "userAgent");
addDebugNav(str, "vendor"); addDebugNav(str, "vendor");
@ -282,11 +284,14 @@ public class ClientMain {
addDebugNav(str, "deviceMemory"); addDebugNav(str, "deviceMemory");
addDebugNav(str, "platform"); addDebugNav(str, "platform");
addDebugNav(str, "product"); addDebugNav(str, "product");
addDebugNavPlugins(str);
str.append('\n'); str.append('\n');
str.append("rootElement.clientWidth = ").append(el == null ? "undefined" : el.getClientWidth()) addDebug(str, "localStorage");
.append('\n'); addDebug(str, "sessionStorage");
str.append("rootElement.clientHeight = ").append(el == null ? "undefined" : el.getClientHeight()) addDebug(str, "indexedDB");
.append('\n'); str.append('\n');
str.append("rootElement.clientWidth = ").append(el == null ? "undefined" : el.getClientWidth()).append('\n');
str.append("rootElement.clientHeight = ").append(el == null ? "undefined" : el.getClientHeight()).append('\n');
addDebug(str, "innerWidth"); addDebug(str, "innerWidth");
addDebug(str, "innerHeight"); addDebug(str, "innerHeight");
addDebug(str, "outerWidth"); addDebug(str, "outerWidth");
@ -297,14 +302,45 @@ public class ClientMain {
addDebugScreen(str, "colorDepth"); addDebugScreen(str, "colorDepth");
addDebugScreen(str, "pixelDepth"); addDebugScreen(str, "pixelDepth");
str.append('\n'); str.append('\n');
addDebug(str, "currentContext"); addDebug(str, "minecraftServer");
str.append('\n'); str.append('\n');
addDebugLocation(str, "href"); addDebugLocation(str, "href");
str.append('\n'); str.append('\n');
String strAfter = str.toString();
String strFinal = strBefore + strAfter;
List<String> additionalInfo = new LinkedList();
try {
TeaVMClientConfigAdapter.instance.getHooks().callCrashReportHook(strFinal, additionalInfo::add);
}catch(Throwable tt) {
System.err.println("Uncaught exception invoking crash report hook!");
EagRuntime.debugPrintStackTraceToSTDERR(tt);
}
if(!isCrashed) {
isCrashed = true;
if(additionalInfo.size() > 0) {
try {
StringBuilder builderFinal = new StringBuilder();
builderFinal.append(strBefore);
builderFinal.append("Got the following messages from the crash report hook registered in eaglercraftXOpts:\n\n");
for(String str2 : additionalInfo) {
builderFinal.append("----------[ CRASH HOOK ]----------\n");
builderFinal.append(str2).append('\n');
builderFinal.append("----------------------------------\n\n");
}
builderFinal.append(strAfter);
strFinal = builderFinal.toString();
}catch(Throwable tt) {
System.err.println("Uncaught exception concatenating crash report hook messages!");
EagRuntime.debugPrintStackTraceToSTDERR(tt);
}
}
if(el == null) { if(el == null) {
Window.alert("Root element not found, crash report was printed to console"); Window.alert("Root element not found, crash report was printed to console");
System.err.println(str.toString()); System.err.println(strFinal);
return; return;
} }
@ -318,7 +354,7 @@ public class ClientMain {
"z-index:100;position:absolute;top:135px;left:10%;right:10%;bottom:50px;background-color:white;border:1px solid #cccccc;overflow-x:hidden;overflow-y:scroll;overflow-wrap:break-word;white-space:pre-wrap;font: 14px monospace;padding:10px;"); "z-index:100;position:absolute;top:135px;left:10%;right:10%;bottom:50px;background-color:white;border:1px solid #cccccc;overflow-x:hidden;overflow-y:scroll;overflow-wrap:break-word;white-space:pre-wrap;font: 14px monospace;padding:10px;");
el.appendChild(img); el.appendChild(img);
el.appendChild(div); el.appendChild(div);
div.appendChild(doc.createTextNode(str.toString())); div.appendChild(doc.createTextNode(strFinal));
PlatformRuntime.removeEventHandlers(); PlatformRuntime.removeEventHandlers();
@ -329,10 +365,29 @@ public class ClientMain {
for (int i = 0; i < s.length; ++i) { for (int i = 0; i < s.length; ++i) {
System.err.println(" " + s[i]); System.err.println(" " + s[i]);
} }
if(additionalInfo.size() > 0) {
for(String str2 : additionalInfo) {
if(str2 != null) {
System.err.println();
System.err.println(" ----------[ CRASH HOOK ]----------");
s = str2.split("[\\r\\n]+");
for(int i = 0; i < s.length; ++i) {
System.err.println(" " + s[i]);
}
System.err.println(" ----------------------------------");
}
}
}
} }
} }
private static String webGLCrashStringCache = null;
private static String addWebGLToCrash() { private static String addWebGLToCrash() {
if(webGLCrashStringCache != null) {
return webGLCrashStringCache;
}
StringBuilder ret = new StringBuilder(); StringBuilder ret = new StringBuilder();
WebGLRenderingContext ctx = PlatformRuntime.webgl; WebGLRenderingContext ctx = PlatformRuntime.webgl;
@ -343,8 +398,12 @@ public class ClientMain {
cvs.setWidth(64); cvs.setWidth(64);
cvs.setHeight(64); cvs.setHeight(64);
ctx = (WebGLRenderingContext)cvs.getContext("webgl2");
if(ctx == null) {
ctx = (WebGLRenderingContext)cvs.getContext("webgl"); ctx = (WebGLRenderingContext)cvs.getContext("webgl");
} }
}
if (ctx != null) { if (ctx != null) {
if (PlatformRuntime.webgl != null) { if (PlatformRuntime.webgl != null) {
@ -367,12 +426,13 @@ public class ClientMain {
ret.append('\n').append("webgl.ext.HDR16f = ") ret.append('\n').append("webgl.ext.HDR16f = ")
.append(ctx.getExtension("EXT_color_buffer_half_float") != null).append('\n'); .append(ctx.getExtension("EXT_color_buffer_half_float") != null).append('\n');
ret.append("webgl.ext.HDR32f = ").append(ctx.getExtension("EXT_color_buffer_float") != null).append('\n'); ret.append("webgl.ext.HDR32f = ").append(ctx.getExtension("EXT_color_buffer_float") != null).append('\n');
ret.append("webgl.ext.HDR32f_linear = ").append(ctx.getExtension("OES_texture_float_linear") != null).append('\n');
}else { }else {
ret.append("Failed to query GPU info!\n"); ret.append("Failed to query GPU info!\n");
} }
return ret.toString(); return webGLCrashStringCache = ret.toString();
} }
public static void showIncompatibleScreen(String t) { public static void showIncompatibleScreen(String t) {
@ -516,6 +576,13 @@ public class ClientMain {
@JSBody(params = { "v" }, script = "try { return \"\"+window.location[v]; } catch(e) { return \"<error>\"; }") @JSBody(params = { "v" }, script = "try { return \"\"+window.location[v]; } catch(e) { return \"<error>\"; }")
private static native String getStringLocation(String var); private static native String getStringLocation(String var);
@JSBody(params = { }, script = "try { var retObj = new Array; if(typeof window.navigator.plugins === \"object\")"
+ "{ var len = window.navigator.plugins.length; if(len > 0) { for(var idx = 0; idx < len; ++idx) {"
+ "var thePlugin = window.navigator.plugins[idx]; retObj.push({ name: thePlugin.name,"
+ "filename: thePlugin.filename, desc: thePlugin.description }); } } } return JSON.stringify(retObj);"
+ "} catch(e) { return \"<error>\"; }")
private static native String getStringNavPlugins();
private static void addDebug(StringBuilder str, String var) { private static void addDebug(StringBuilder str, String var) {
str.append("window.").append(var).append(" = ").append(getString(var)).append('\n'); str.append("window.").append(var).append(" = ").append(getString(var)).append('\n');
} }
@ -524,6 +591,10 @@ public class ClientMain {
str.append("window.navigator.").append(var).append(" = ").append(getStringNav(var)).append('\n'); str.append("window.navigator.").append(var).append(" = ").append(getStringNav(var)).append('\n');
} }
private static void addDebugNavPlugins(StringBuilder str) {
str.append("window.navigator.plugins = ").append(getStringNavPlugins()).append('\n');
}
private static void addDebugScreen(StringBuilder str, String var) { private static void addDebugScreen(StringBuilder str, String var) {
str.append("window.screen.").append(var).append(" = ").append(getStringScreen(var)).append('\n'); str.append("window.screen.").append(var).append(" = ").append(getStringScreen(var)).append('\n');
} }

View File

@ -71,15 +71,15 @@ public class DebugConsoleWindow {
destroyWindow(); destroyWindow();
} }
}); });
if ("true".equals(parent.getLocalStorage() if(parent.getLocalStorage() != null && "true".equals(parent.getLocalStorage().getItem(PlatformRuntime.getClientConfigAdapter().getLocalStorageNamespace() + ".showDebugConsole"))) {
.getItem(PlatformRuntime.getClientConfigAdapter().getLocalStorageNamespace() + ".showDebugConsole"))) {
showDebugConsole0(); showDebugConsole0();
} }
} }
public static void showDebugConsole() { public static void showDebugConsole() {
parent.getLocalStorage().setItem( if(parent.getLocalStorage() != null) {
PlatformRuntime.getClientConfigAdapter().getLocalStorageNamespace() + ".showDebugConsole", "true"); parent.getLocalStorage().setItem(PlatformRuntime.getClientConfigAdapter().getLocalStorageNamespace() + ".showDebugConsole", "true");
}
showDebugConsole0(); showDebugConsole0();
} }
@ -120,7 +120,9 @@ public class DebugConsoleWindow {
public void handleEvent(Event evt) { public void handleEvent(Event evt) {
if (logger != null) { if (logger != null) {
logger = null; logger = null;
parent.getLocalStorage().setItem("_eaglercraftX.showDebugConsole", "false"); if(parent.getLocalStorage() != null) {
parent.getLocalStorage().setItem(PlatformRuntime.getClientConfigAdapter().getLocalStorageNamespace() + ".showDebugConsole", "false");
}
} }
} }
}; };

View File

@ -68,6 +68,7 @@ public class TeaVMClientConfigAdapter implements IClientConfigAdapter {
private String localStorageNamespace = "_eaglercraftX"; private String localStorageNamespace = "_eaglercraftX";
private final TeaVMClientConfigAdapterHooks hooks = new TeaVMClientConfigAdapterHooks(); private final TeaVMClientConfigAdapterHooks hooks = new TeaVMClientConfigAdapterHooks();
private boolean enableMinceraft = true; private boolean enableMinceraft = true;
private boolean crashOnUncaughtExceptions = false;
public void loadNative(JSObject jsObject) { public void loadNative(JSObject jsObject) {
integratedServerOpts = new JSONObject(); integratedServerOpts = new JSONObject();
@ -93,6 +94,7 @@ public class TeaVMClientConfigAdapter implements IClientConfigAdapter {
allowFNAWSkins = !demoMode && eaglercraftXOpts.getAllowFNAWSkins(true); allowFNAWSkins = !demoMode && eaglercraftXOpts.getAllowFNAWSkins(true);
localStorageNamespace = eaglercraftXOpts.getLocalStorageNamespace(EaglercraftVersion.localStorageNamespace); localStorageNamespace = eaglercraftXOpts.getLocalStorageNamespace(EaglercraftVersion.localStorageNamespace);
enableMinceraft = eaglercraftXOpts.getEnableMinceraft(true); enableMinceraft = eaglercraftXOpts.getEnableMinceraft(true);
crashOnUncaughtExceptions = eaglercraftXOpts.getCrashOnUncaughtExceptions(false);
JSEaglercraftXOptsHooks hooksObj = eaglercraftXOpts.getHooks(); JSEaglercraftXOptsHooks hooksObj = eaglercraftXOpts.getHooks();
if (hooksObj != null) { if (hooksObj != null) {
hooks.loadHooks(hooksObj); hooks.loadHooks(hooksObj);
@ -105,6 +107,7 @@ public class TeaVMClientConfigAdapter implements IClientConfigAdapter {
integratedServerOpts.put("allowUpdateDL", isAllowUpdateDL); integratedServerOpts.put("allowUpdateDL", isAllowUpdateDL);
integratedServerOpts.put("allowVoiceClient", allowVoiceClient); integratedServerOpts.put("allowVoiceClient", allowVoiceClient);
integratedServerOpts.put("allowFNAWSkins", allowFNAWSkins); integratedServerOpts.put("allowFNAWSkins", allowFNAWSkins);
integratedServerOpts.put("crashOnUncaughtExceptions", crashOnUncaughtExceptions);
JSArrayReader<JSEaglercraftXOptsServer> serversArray = eaglercraftXOpts.getServers(); JSArrayReader<JSEaglercraftXOptsServer> serversArray = eaglercraftXOpts.getServers();
if (serversArray != null) { if (serversArray != null) {
@ -194,6 +197,7 @@ public class TeaVMClientConfigAdapter implements IClientConfigAdapter {
localStorageNamespace = eaglercraftOpts.optString("localStorageNamespace", localStorageNamespace = eaglercraftOpts.optString("localStorageNamespace",
EaglercraftVersion.localStorageNamespace); EaglercraftVersion.localStorageNamespace);
enableMinceraft = eaglercraftOpts.optBoolean("enableMinceraft", true); enableMinceraft = eaglercraftOpts.optBoolean("enableMinceraft", true);
crashOnUncaughtExceptions = eaglercraftOpts.optBoolean("crashOnUncaughtExceptions", false);
JSONArray serversArray = eaglercraftOpts.optJSONArray("servers"); JSONArray serversArray = eaglercraftOpts.optJSONArray("servers");
if (serversArray != null) { if (serversArray != null) {
for (int i = 0, l = serversArray.length(); i < l; ++i) { for (int i = 0, l = serversArray.length(); i < l; ++i) {
@ -384,6 +388,7 @@ public class TeaVMClientConfigAdapter implements IClientConfigAdapter {
jsonObject.put("allowFNAWSkins", allowFNAWSkins); jsonObject.put("allowFNAWSkins", allowFNAWSkins);
jsonObject.put("localStorageNamespace", localStorageNamespace); jsonObject.put("localStorageNamespace", localStorageNamespace);
jsonObject.put("enableMinceraft", enableMinceraft); jsonObject.put("enableMinceraft", enableMinceraft);
jsonObject.put("crashOnUncaughtExceptions", crashOnUncaughtExceptions);
JSONArray serversArr = new JSONArray(); JSONArray serversArr = new JSONArray();
for (int i = 0, l = defaultServers.size(); i < l; ++i) { for (int i = 0, l = defaultServers.size(); i < l; ++i) {
DefaultServer srv = defaultServers.get(i); DefaultServer srv = defaultServers.get(i);

View File

@ -1,5 +1,6 @@
package net.lax1dude.eaglercraft.v1_8.internal.teavm; package net.lax1dude.eaglercraft.v1_8.internal.teavm;
import java.util.function.Consumer;
import java.util.function.Supplier; import java.util.function.Supplier;
import org.teavm.interop.Async; import org.teavm.interop.Async;
@ -41,6 +42,7 @@ public class TeaVMClientConfigAdapterHooks implements IClientConfigAdapterHooks
private LocalStorageSaveHook saveHook = null; private LocalStorageSaveHook saveHook = null;
private LocalStorageLoadHook loadHook = null; private LocalStorageLoadHook loadHook = null;
private CrashReportHook crashHook = null;
@JSFunctor @JSFunctor
private static interface LocalStorageSaveHook extends JSObject { private static interface LocalStorageSaveHook extends JSObject {
@ -72,6 +74,25 @@ public class TeaVMClientConfigAdapterHooks implements IClientConfigAdapterHooks
} }
} }
@JSFunctor
private static interface CrashReportHook extends JSObject {
void call(String crashReport, CustomMessageCB customMessageCB);
}
@JSFunctor
private static interface CustomMessageCB extends JSObject {
void call(String msg);
}
@Override
public void callCrashReportHook(String crashReport, Consumer<String> customMessageCB) {
if(crashHook != null) {
callHookSafeSync("crashReportShow", () -> {
crashHook.call(crashReport, (msg) -> customMessageCB.accept(msg));
});
}
}
private static void callHookSafe(String identifer, Runnable hooker) { private static void callHookSafe(String identifer, Runnable hooker) {
Window.setTimeout(() -> { Window.setTimeout(() -> {
try { try {
@ -83,6 +104,22 @@ public class TeaVMClientConfigAdapterHooks implements IClientConfigAdapterHooks
}, 0); }, 0);
} }
@Async
private static native void callHookSafeSync(String identifer, Runnable hooker);
private static void callHookSafeSync(String identifer, Runnable hooker, final AsyncCallback<Void> cb) {
Window.setTimeout(() -> {
try {
hooker.run();
}catch(Throwable t) {
logger.error("Caught exception while invoking eaglercraftXOpts \"{}\" hook!", identifer);
logger.error(t);
}finally {
cb.complete(null);
}
}, 0);
}
@Async @Async
private static native Object callHookSafeWithReturn(String identifer, Supplier<Object> hooker); private static native Object callHookSafeWithReturn(String identifer, Supplier<Object> hooker);
@ -104,5 +141,6 @@ public class TeaVMClientConfigAdapterHooks implements IClientConfigAdapterHooks
public void loadHooks(JSEaglercraftXOptsHooks hooks) { public void loadHooks(JSEaglercraftXOptsHooks hooks) {
saveHook = (LocalStorageSaveHook)hooks.getLocalStorageSavedHook(); saveHook = (LocalStorageSaveHook)hooks.getLocalStorageSavedHook();
loadHook = (LocalStorageLoadHook)hooks.getLocalStorageLoadedHook(); loadHook = (LocalStorageLoadHook)hooks.getLocalStorageLoadedHook();
crashHook = (CrashReportHook)hooks.getCrashReportHook();
} }
} }

View File

@ -33,4 +33,7 @@ public abstract class JSEaglercraftXOptsHooks implements JSObject {
@JSBody(script = "return (typeof this.localStorageLoaded === \"function\") ? this.localStorageLoaded : null;") @JSBody(script = "return (typeof this.localStorageLoaded === \"function\") ? this.localStorageLoaded : null;")
public native JSObject getLocalStorageLoadedHook(); public native JSObject getLocalStorageLoadedHook();
@JSBody(script = "return (typeof this.crashReportShow === \"function\") ? this.crashReportShow : null;")
public native JSObject getCrashReportHook();
} }

View File

@ -117,4 +117,7 @@ public abstract class JSEaglercraftXOptsRoot implements JSObject {
"def" }, script = "return (typeof this.enableMinceraft === \"boolean\") ? this.enableMinceraft : def;") "def" }, script = "return (typeof this.enableMinceraft === \"boolean\") ? this.enableMinceraft : def;")
public native boolean getEnableMinceraft(boolean defaultValue); public native boolean getEnableMinceraft(boolean defaultValue);
@JSBody(params = { "def" }, script = "return (typeof this.crashOnUncaughtExceptions === \"boolean\") ? this.crashOnUncaughtExceptions : def;")
public native boolean getCrashOnUncaughtExceptions(boolean defaultValue);
} }