Fix <clinit> elimination in case of native methods

This commit is contained in:
Alexey Andreev 2020-02-10 16:37:32 +03:00
parent 862b5e79a1
commit 3b1dae4412
4 changed files with 27 additions and 19 deletions

View File

@ -180,7 +180,7 @@ public class RuntimeRenderer {
return false; return false;
} }
MethodReader method = cls.getMethod(STRING_INTERN_METHOD); MethodReader method = cls.getMethod(STRING_INTERN_METHOD);
return method != null && method.getProgram() != null; return method != null && method.hasModifier(ElementModifier.NATIVE);
} }
private void renderRuntimeObjcls() throws IOException { private void renderRuntimeObjcls() throws IOException {

View File

@ -49,9 +49,11 @@ public class PreOptimizingClassHolderSource implements ClassHolderSource {
return cls; return cls;
} }
for (MethodHolder method : cls.getMethods()) { for (MethodHolder method : cls.getMethods()) {
if (method.getProgram() != null) {
new GlobalValueNumbering(true).optimize(method.getProgram()); new GlobalValueNumbering(true).optimize(method.getProgram());
new UnusedVariableElimination().optimize(method, method.getProgram()); new UnusedVariableElimination().optimize(method, method.getProgram());
} }
}
return cls; return cls;
} }
} }

View File

@ -129,7 +129,9 @@ public class ClassRefsRenamer extends AbstractInstructionVisitor {
renamedMethod.setLevel(method.getLevel()); renamedMethod.setLevel(method.getLevel());
renamedMethod.setProgram(method.getProgram()); renamedMethod.setProgram(method.getProgram());
rename(method.getAnnotations(), renamedMethod.getAnnotations()); rename(method.getAnnotations(), renamedMethod.getAnnotations());
if (renamedMethod.getProgram() != null) {
rename(renamedMethod.getProgram()); rename(renamedMethod.getProgram());
}
renamedMethod.setTypeParameters(rename(method.getTypeParameters())); renamedMethod.setTypeParameters(rename(method.getTypeParameters()));
GenericValueType genericResultType = method.getGenericResultType(); GenericValueType genericResultType = method.getGenericResultType();

View File

@ -79,7 +79,9 @@ public class Parser {
ValueType[] signature = MethodDescriptor.parseSignature(node.desc); ValueType[] signature = MethodDescriptor.parseSignature(node.desc);
MethodHolder method = new MethodHolder(referenceCache.getCached(new MethodDescriptor(node.name, signature))); MethodHolder method = new MethodHolder(referenceCache.getCached(new MethodDescriptor(node.name, signature)));
parseModifiers(node.access, method, DECL_METHOD); parseModifiers(node.access, method, DECL_METHOD);
parseAnnotations(method.getAnnotations(), node.visibleAnnotations, node.invisibleAnnotations);
if (node.instructions.size() > 0) {
ProgramParser programParser = new ProgramParser(referenceCache); ProgramParser programParser = new ProgramParser(referenceCache);
programParser.setFileName(fileName); programParser.setFileName(fileName);
Program program = programParser.parse(node); Program program = programParser.parse(node);
@ -90,12 +92,14 @@ public class Parser {
method.setProgram(program); method.setProgram(program);
applyDebugNames(program, phiUpdater, programParser, argumentMapping); applyDebugNames(program, phiUpdater, programParser, argumentMapping);
parseAnnotations(method.getAnnotations(), node.visibleAnnotations, node.invisibleAnnotations);
applyDebugNames(program, phiUpdater, programParser, applyDebugNames(program, phiUpdater, programParser,
applySignature(program, method.getDescriptor().getParameterTypes())); applySignature(program, method.getDescriptor().getParameterTypes()));
while (program.variableCount() <= method.parameterCount()) { while (program.variableCount() <= method.parameterCount()) {
program.createVariable(); program.createVariable();
} }
}
if (node.annotationDefault != null) { if (node.annotationDefault != null) {
method.setAnnotationDefault(parseAnnotationValue(node.annotationDefault)); method.setAnnotationDefault(parseAnnotationValue(node.annotationDefault));
} }