Fix making constructors final

This commit is contained in:
modmuss50 2020-04-06 22:52:49 +01:00
parent 0ae8535c40
commit 232118e69e
2 changed files with 50 additions and 33 deletions

View file

@ -312,19 +312,29 @@ public class AccessWidener {
return (i & ~(Opcodes.ACC_PRIVATE)) | Opcodes.ACC_PROTECTED;
}
private static int makeFinalIfPrivate(int i) {
if ((i & Opcodes.ACC_PRIVATE) != 0) {
return i | Opcodes.ACC_FINAL;
private static int makeFinalIfPrivate(int access, String name, int ownerAccess) {
// Dont make constructors final
if (name.equals("<init>")) {
return access;
}
return i;
// Skip interface and static methods
if ((ownerAccess & (Opcodes.ACC_INTERFACE | Opcodes.ACC_STATIC)) != 0) {
return access;
}
if ((access & Opcodes.ACC_PRIVATE) != 0) {
return access | Opcodes.ACC_FINAL;
}
return access;
}
private static int removeFinal(int i) {
return i & ~Opcodes.ACC_FINAL;
}
public interface Access extends IntUnaryOperator {
public interface Access extends AccessOperator {
Access makeAccessible();
Access makeExtendable();
@ -333,14 +343,14 @@ public class AccessWidener {
}
public enum ClassAccess implements Access {
DEFAULT(i -> i),
ACCESSIBLE(i -> makePublic(i)),
EXTENDABLE(i -> makePublic(removeFinal(i))),
ACCESSIBLE_EXTENDABLE(i -> makePublic(removeFinal(i)));
DEFAULT((access, name, ownerAccess) -> access),
ACCESSIBLE((access, name, ownerAccess) -> makePublic(access)),
EXTENDABLE((access, name, ownerAccess) -> makePublic(removeFinal(access))),
ACCESSIBLE_EXTENDABLE((access, name, ownerAccess) -> makePublic(removeFinal(access)));
private final IntUnaryOperator operator;
private final AccessOperator operator;
ClassAccess(IntUnaryOperator operator) {
ClassAccess(AccessOperator operator) {
this.operator = operator;
}
@ -368,20 +378,20 @@ public class AccessWidener {
}
@Override
public int applyAsInt(int operand) {
return operator.applyAsInt(operand);
public int apply(int access, String targetName, int ownerAccess) {
return operator.apply(access, targetName, ownerAccess);
}
}
public enum MethodAccess implements Access {
DEFAULT(i -> i),
ACCESSIBLE(i -> makePublic(makeFinalIfPrivate(i))),
EXTENDABLE(i -> makeProtected(removeFinal(i))),
ACCESSIBLE_EXTENDABLE(i -> makePublic(removeFinal(i)));
DEFAULT((access, name, ownerAccess) -> access),
ACCESSIBLE((access, name, ownerAccess) -> makePublic(makeFinalIfPrivate(access, name, ownerAccess))),
EXTENDABLE((access, name, ownerAccess) -> makeProtected(removeFinal(access))),
ACCESSIBLE_EXTENDABLE((access, name, owner) -> makePublic(removeFinal(access)));
private final IntUnaryOperator operator;
private final AccessOperator operator;
MethodAccess(IntUnaryOperator operator) {
MethodAccess(AccessOperator operator) {
this.operator = operator;
}
@ -409,20 +419,20 @@ public class AccessWidener {
}
@Override
public int applyAsInt(int operand) {
return operator.applyAsInt(operand);
public int apply(int access, String targetName, int ownerAccess) {
return operator.apply(access, targetName, ownerAccess);
}
}
public enum FieldAccess implements Access {
DEFAULT(i -> i),
ACCESSIBLE(i -> makePublic(i)),
MUTABLE(i -> removeFinal(i)),
ACCESSIBLE_MUTABLE(i -> makePublic(removeFinal(i)));
DEFAULT((access, name, ownerAccess) -> access),
ACCESSIBLE((access, name, ownerAccess) -> makePublic(access)),
MUTABLE((access, name, ownerAccess) -> removeFinal(access)),
ACCESSIBLE_MUTABLE((access, name, ownerAccess) -> makePublic(removeFinal(access)));
private final IntUnaryOperator operator;
private final AccessOperator operator;
FieldAccess(IntUnaryOperator operator) {
FieldAccess(AccessOperator operator) {
this.operator = operator;
}
@ -450,8 +460,13 @@ public class AccessWidener {
}
@Override
public int applyAsInt(int operand) {
return operator.applyAsInt(operand);
public int apply(int access, String targetName, int ownerAccess) {
return operator.apply(access, targetName, ownerAccess);
}
}
@FunctionalInterface
public interface AccessOperator {
int apply(int access, String targetName, int ownerAccess);
}
}

View file

@ -168,6 +168,7 @@ public class AccessWidenerJarProcessor implements JarProcessor {
private class AccessTransformer extends ClassVisitor {
private String className;
private int classAccess;
private AccessTransformer(ClassVisitor classVisitor) {
super(Opcodes.ASM7, classVisitor);
@ -176,9 +177,10 @@ public class AccessWidenerJarProcessor implements JarProcessor {
@Override
public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) {
className = name;
classAccess = access;
super.visit(
version,
accessWidener.getClassAccess(name).applyAsInt(access),
accessWidener.getClassAccess(name).apply(access, name, classAccess),
name,
signature,
superName,
@ -192,14 +194,14 @@ public class AccessWidenerJarProcessor implements JarProcessor {
name,
outerName,
innerName,
accessWidener.getClassAccess(name).applyAsInt(access)
accessWidener.getClassAccess(name).apply(access, name, classAccess)
);
}
@Override
public FieldVisitor visitField(int access, String name, String descriptor, String signature, Object value) {
return super.visitField(
accessWidener.getFieldAccess(new EntryTriple(className, name, descriptor)).applyAsInt(access),
accessWidener.getFieldAccess(new EntryTriple(className, name, descriptor)).apply(access, name, classAccess),
name,
descriptor,
signature,
@ -210,7 +212,7 @@ public class AccessWidenerJarProcessor implements JarProcessor {
@Override
public MethodVisitor visitMethod(int access, String name, String descriptor, String signature, String[] exceptions) {
return new AccessWidenerMethodVisitor(super.visitMethod(
accessWidener.getMethodAccess(new EntryTriple(className, name, descriptor)).applyAsInt(access),
accessWidener.getMethodAccess(new EntryTriple(className, name, descriptor)).apply(access, name, classAccess),
name,
descriptor,
signature,