From 545eb86ac43dfaaa5976bc9ae491c2fadf680830 Mon Sep 17 00:00:00 2001 From: Wagyourtail Date: Tue, 30 Jul 2024 23:10:44 -0500 Subject: [PATCH] move equals --- .../wagyourtail/jvmdg/ClassDowngrader.java | 27 +------------------ .../xyz/wagyourtail/jvmdg/util/Utils.java | 19 +++++++++++++ 2 files changed, 20 insertions(+), 26 deletions(-) diff --git a/src/main/java/xyz/wagyourtail/jvmdg/ClassDowngrader.java b/src/main/java/xyz/wagyourtail/jvmdg/ClassDowngrader.java index 40e140f4..d95142fe 100644 --- a/src/main/java/xyz/wagyourtail/jvmdg/ClassDowngrader.java +++ b/src/main/java/xyz/wagyourtail/jvmdg/ClassDowngrader.java @@ -10,8 +10,6 @@ import org.objectweb.asm.Type; import org.objectweb.asm.tree.ClassNode; import org.objectweb.asm.tree.MethodNode; -import org.objectweb.asm.util.Textifier; -import org.objectweb.asm.util.TraceClassVisitor; import xyz.wagyourtail.jvmdg.asm.ASMUtils; import xyz.wagyourtail.jvmdg.classloader.DowngradingClassLoader; import xyz.wagyourtail.jvmdg.cli.Flags; @@ -25,12 +23,10 @@ import java.io.*; import java.lang.instrument.IllegalClassFormatException; import java.lang.reflect.InvocationTargetException; -import java.net.MalformedURLException; import java.net.URL; import java.net.URLClassLoader; import java.util.*; import java.util.concurrent.atomic.AtomicReference; -import java.util.logging.Level; public class ClassDowngrader implements Closeable { /** @@ -377,7 +373,7 @@ public ClassNode apply(String s) { byte[] currentVal = current.get(key); byte[] vsVal = vs.getValue(); // equal after version info - if (!equals(currentVal, 8, currentVal.length, vsVal, 8, vsVal.length)) { + if (!Utils.equals(currentVal, 8, currentVal.length, vsVal, 8, vsVal.length)) { current.put(key, vsVal); outputs.put("META-INF/versions/" + vs.getKey() + "/" + key, vsVal); } @@ -403,27 +399,6 @@ public ClassNode apply(String s) { return outputs; } - public static boolean equals( - byte[] a, int aFromIndex, int aToIndex, - byte[] b, int bFromIndex, int bToIndex - ) { - int aLength = aToIndex - aFromIndex; - int bLength = bToIndex - bFromIndex; - if (aLength != bLength) { - return false; - } - if (aLength == 0) { - return true; - } - for (int i = 0; i < aLength; i++) { - if (a[aFromIndex + i] != b[bFromIndex + i]) { - return false; - } - } - return true; - } - - public byte[] classNodeToBytes(@NotNull final ClassNode node) { ClassWriter cw = new ClassWriter(ClassWriter.COMPUTE_MAXS); node.accept(cw); diff --git a/src/shared/java/xyz/wagyourtail/jvmdg/util/Utils.java b/src/shared/java/xyz/wagyourtail/jvmdg/util/Utils.java index 6b6a5107..1155e271 100644 --- a/src/shared/java/xyz/wagyourtail/jvmdg/util/Utils.java +++ b/src/shared/java/xyz/wagyourtail/jvmdg/util/Utils.java @@ -94,4 +94,23 @@ public static void sneakyThrow(Throwable t) throws T { throw (T) t; } + public static boolean equals( + byte[] a, int aFromIndex, int aToIndex, + byte[] b, int bFromIndex, int bToIndex + ) { + int aLength = aToIndex - aFromIndex; + int bLength = bToIndex - bFromIndex; + if (aLength != bLength) { + return false; + } + if (aLength == 0) { + return true; + } + for (int i = 0; i < aLength; i++) { + if (a[aFromIndex + i] != b[bFromIndex + i]) { + return false; + } + } + return true; + } }