proguard.optimize.info.SuperInvocationMarker Maven / Gradle / Ivy
Go to download
ProGuard is a free Java class file shrinker, optimizer, and obfuscator. It removes unused classes, fields, methods, and attributes. It then optimizes the bytecode. It then renames the remaining classes, fields, and methods using short meaningless names. Finally, it preverifies the processed code for Java 6 or for Java Micro Edition.
/*
* ProGuard -- shrinking, optimization, obfuscation, and preverification
* of Java bytecode.
*
* Copyright (c) 2002-2007 Eric Lafortune ([email protected])
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package proguard.optimize.info;
import proguard.classfile.*;
import proguard.classfile.attribute.CodeAttribute;
import proguard.classfile.constant.RefConstant;
import proguard.classfile.constant.visitor.ConstantVisitor;
import proguard.classfile.instruction.*;
import proguard.classfile.instruction.visitor.InstructionVisitor;
import proguard.classfile.util.SimplifiedVisitor;
/**
* This InstructionVisitor marks all methods that invoke super methods (other
* than initializers) from the instructions that it visits.
*
* @author Eric Lafortune
*/
public class SuperInvocationMarker
extends SimplifiedVisitor
implements InstructionVisitor,
ConstantVisitor
{
private boolean invokesSuperMethods;
// Implementations for InstructionVisitor.
public void visitAnyInstruction(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, Instruction instruction) {}
public void visitConstantInstruction(Clazz clazz, Method method, CodeAttribute codeAttribute, int offset, ConstantInstruction constantInstruction)
{
if (constantInstruction.opcode == InstructionConstants.OP_INVOKESPECIAL)
{
invokesSuperMethods = false;
clazz.constantPoolEntryAccept(constantInstruction.constantIndex, this);
if (invokesSuperMethods)
{
setInvokesSuperMethods(method);
}
}
}
// Implementations for ConstantVisitor.
public void visitAnyMethodrefConstant(Clazz clazz, RefConstant refConstant)
{
invokesSuperMethods =
!clazz.equals(refConstant.referencedClass) &&
!refConstant.getName(clazz).equals(ClassConstants.INTERNAL_METHOD_NAME_INIT);
}
// Small utility methods.
private static void setInvokesSuperMethods(Method method)
{
MethodOptimizationInfo info = MethodOptimizationInfo.getMethodOptimizationInfo(method);
if (info != null)
{
info.setInvokesSuperMethods();
}
}
public static boolean invokesSuperMethods(Method method)
{
MethodOptimizationInfo info = MethodOptimizationInfo.getMethodOptimizationInfo(method);
return info == null || info.invokesSuperMethods();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy