From 5de7eedc35e24adb03e21c667dfbca5cfbd176a5 Mon Sep 17 00:00:00 2001 From: Zaxar163 Date: Tue, 17 Sep 2019 18:14:32 +0200 Subject: [PATCH] =?UTF-8?q?[FIX]=20=D0=95=D1=89=D1=91=20=D0=B1=D0=B0=D0=B3?= =?UTF-8?q?=D0=B8=20=D0=B2=20asm.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../gravit/launchserver/asm/NodeUtils.java | 26 ++++++++++++------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/LaunchServer/src/main/java/pro/gravit/launchserver/asm/NodeUtils.java b/LaunchServer/src/main/java/pro/gravit/launchserver/asm/NodeUtils.java index e47c970e..90ed2754 100644 --- a/LaunchServer/src/main/java/pro/gravit/launchserver/asm/NodeUtils.java +++ b/LaunchServer/src/main/java/pro/gravit/launchserver/asm/NodeUtils.java @@ -3,6 +3,7 @@ import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import org.objectweb.asm.ClassReader; @@ -42,16 +43,21 @@ public static ClassNode forClass(String clazz, int flags, ClassMetadataReader r) } public static List annots(String clazz, String method, ClassMetadataReader r) { - List ret = new ArrayList<>(); - ClassNode n = forClass(clazz, ClassReader.SKIP_CODE | ClassReader.SKIP_DEBUG, r); - if (n.visibleAnnotations != null) ret.addAll(n.visibleAnnotations); - if (n.invisibleAnnotations != null) ret.addAll(n.invisibleAnnotations); - for (MethodNode m : n.methods) - if (method.equals(m.name)) { - if (m.visibleAnnotations != null) ret.addAll(m.visibleAnnotations); - if (m.invisibleAnnotations != null) ret.addAll(m.invisibleAnnotations); - } - return ret; + if (clazz.startsWith("L")) clazz = Type.getType(clazz).getInternalName(); + try { + List ret = new ArrayList<>(); + ClassNode n = forClass(clazz, ClassReader.SKIP_CODE | ClassReader.SKIP_DEBUG, r); + if (n.visibleAnnotations != null) ret.addAll(n.visibleAnnotations); + if (n.invisibleAnnotations != null) ret.addAll(n.invisibleAnnotations); + for (MethodNode m : n.methods) + if (method.equals(m.name)) { + if (m.visibleAnnotations != null) ret.addAll(m.visibleAnnotations); + if (m.invisibleAnnotations != null) ret.addAll(m.invisibleAnnotations); + } + return ret; + } catch (Throwable e) { + return Collections.emptyList(); + } } private static int doMethodEmulation(String desc) {