mirror of
https://github.com/2006-Scape/Parabot.git
synced 2026-07-03 00:37:55 +00:00
Merge branch 'master' of github.com:Parabot/Parabot
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
package org.parabot.core.asm;
|
||||
|
||||
import java.lang.reflect.Modifier;
|
||||
|
||||
import org.objectweb.asm.Opcodes;
|
||||
import org.objectweb.asm.tree.ClassNode;
|
||||
import org.objectweb.asm.tree.FieldNode;
|
||||
@@ -114,5 +116,29 @@ public class ASMUtils implements Opcodes {
|
||||
}
|
||||
throw new RuntimeException("eek " + c);
|
||||
}
|
||||
|
||||
public static void makePublic(ClassNode node) {
|
||||
if (!Modifier.isPublic(node.access)) {
|
||||
if (Modifier.isPrivate(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PRIVATE);
|
||||
}
|
||||
if (Modifier.isProtected(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PROTECTED);
|
||||
}
|
||||
node.access = node.access | Opcodes.ACC_PUBLIC;
|
||||
}
|
||||
}
|
||||
|
||||
public static void makePublic(MethodNode node) {
|
||||
if (!Modifier.isPublic(node.access)) {
|
||||
if (Modifier.isPrivate(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PRIVATE);
|
||||
}
|
||||
if (Modifier.isProtected(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PROTECTED);
|
||||
}
|
||||
node.access = node.access | Opcodes.ACC_PUBLIC;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1,9 +1,7 @@
|
||||
package org.parabot.core.asm.adapters;
|
||||
|
||||
import java.lang.reflect.Modifier;
|
||||
|
||||
import org.objectweb.asm.Opcodes;
|
||||
import org.objectweb.asm.tree.ClassNode;
|
||||
import org.objectweb.asm.tree.MethodNode;
|
||||
import org.parabot.core.Core;
|
||||
import org.parabot.core.asm.ASMUtils;
|
||||
import org.parabot.core.asm.interfaces.Injectable;
|
||||
@@ -46,14 +44,11 @@ public class AddInterfaceAdapter implements Injectable {
|
||||
}
|
||||
|
||||
protected static void addInterface(ClassNode node, String i) {
|
||||
if (!Modifier.isPublic(node.access)) {
|
||||
if (Modifier.isPrivate(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PRIVATE);
|
||||
ASMUtils.makePublic(node);
|
||||
for(MethodNode mn : node.methods) {
|
||||
if(mn.desc.startsWith("<init")) {
|
||||
ASMUtils.makePublic(mn);
|
||||
}
|
||||
if (Modifier.isProtected(node.access)) {
|
||||
node.access = node.access & (~Opcodes.ACC_PROTECTED);
|
||||
}
|
||||
node.access = node.access | Opcodes.ACC_PUBLIC;
|
||||
}
|
||||
node.interfaces.add(i);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user