aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/cc/polyfrost/oneconfig/internal
diff options
context:
space:
mode:
authorDeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com>2022-06-16 18:54:26 +0200
committerDeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com>2022-06-16 18:54:26 +0200
commit4db4afb9156edfd7d5485f80e18739d205e23d27 (patch)
tree41f5225f9b542c3374a1bc897710243aa3278326 /src/main/java/cc/polyfrost/oneconfig/internal
parent7cf9731db5f34c8a413746161957e0e094e2374d (diff)
parent416b60ef717f4f7183f54a4a7362e0c540928c8d (diff)
downloadOneConfig-4db4afb9156edfd7d5485f80e18739d205e23d27.tar.gz
OneConfig-4db4afb9156edfd7d5485f80e18739d205e23d27.tar.bz2
OneConfig-4db4afb9156edfd7d5485f80e18739d205e23d27.zip
Merge branch 'master' of github.com:Polyfrost/OneConfig
Diffstat (limited to 'src/main/java/cc/polyfrost/oneconfig/internal')
-rw-r--r--src/main/java/cc/polyfrost/oneconfig/internal/OneConfig.java2
-rw-r--r--src/main/java/cc/polyfrost/oneconfig/internal/mixin/OptifineConfigMixin.java21
-rw-r--r--src/main/java/cc/polyfrost/oneconfig/internal/plugin/OptifineConfigHook.java23
3 files changed, 45 insertions, 1 deletions
diff --git a/src/main/java/cc/polyfrost/oneconfig/internal/OneConfig.java b/src/main/java/cc/polyfrost/oneconfig/internal/OneConfig.java
index 13e34ff..479192d 100644
--- a/src/main/java/cc/polyfrost/oneconfig/internal/OneConfig.java
+++ b/src/main/java/cc/polyfrost/oneconfig/internal/OneConfig.java
@@ -36,7 +36,7 @@ public class OneConfig {
public static void preLaunch() {
if (preLaunched) return;
try {
- OneConfig.class.getResourceAsStream("net/minecraft/world/World");
+ Class.forName("net.minecraft.world.World");
LOGGER.warn("OneConfig is NOT obfuscated!");
isObfuscated = false;
} catch (Exception ignored) {
diff --git a/src/main/java/cc/polyfrost/oneconfig/internal/mixin/OptifineConfigMixin.java b/src/main/java/cc/polyfrost/oneconfig/internal/mixin/OptifineConfigMixin.java
new file mode 100644
index 0000000..bc1d400
--- /dev/null
+++ b/src/main/java/cc/polyfrost/oneconfig/internal/mixin/OptifineConfigMixin.java
@@ -0,0 +1,21 @@
+package cc.polyfrost.oneconfig.internal.mixin;
+
+import cc.polyfrost.oneconfig.internal.plugin.OptifineConfigHook;
+import org.spongepowered.asm.mixin.Dynamic;
+import org.spongepowered.asm.mixin.Mixin;
+import org.spongepowered.asm.mixin.Pseudo;
+import org.spongepowered.asm.mixin.injection.At;
+import org.spongepowered.asm.mixin.injection.Inject;
+import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
+
+@Pseudo
+@Mixin(targets = "Config", remap = false)
+public class OptifineConfigMixin {
+ @Dynamic("OptiFine")
+ @Inject(method = "isFastRender", at = @At("HEAD"), cancellable = true)
+ private static void cancelFastRender(CallbackInfoReturnable<Boolean> cir) {
+ if (OptifineConfigHook.shouldNotApplyFastRender()) {
+ cir.setReturnValue(false);
+ }
+ }
+}
diff --git a/src/main/java/cc/polyfrost/oneconfig/internal/plugin/OptifineConfigHook.java b/src/main/java/cc/polyfrost/oneconfig/internal/plugin/OptifineConfigHook.java
new file mode 100644
index 0000000..69d1f2e
--- /dev/null
+++ b/src/main/java/cc/polyfrost/oneconfig/internal/plugin/OptifineConfigHook.java
@@ -0,0 +1,23 @@
+package cc.polyfrost.oneconfig.internal.plugin;
+
+import cc.polyfrost.oneconfig.gui.OneConfigGui;
+import cc.polyfrost.oneconfig.libs.universal.UScreen;
+import cc.polyfrost.oneconfig.utils.gui.GuiUtils;
+import net.minecraft.client.gui.GuiScreen;
+
+import java.util.Optional;
+
+public class OptifineConfigHook {
+
+ public static boolean shouldNotApplyFastRender() {
+ if (UScreen.getCurrentScreen() instanceof OneConfigGui) {
+ return true;
+ }
+ for (Optional<GuiScreen> screen : GuiUtils.getScreenQueue()) {
+ if (screen.isPresent() && screen.get() instanceof OneConfigGui) {
+ return true;
+ }
+ }
+ return false;
+ }
+}