blob: fc212f6fbee2ada5f84ae561df912fb890ca8e9b [file] [log] [blame]
/*
* ProGuard -- shrinking, optimization, obfuscation, and preverification
* of Java bytecode.
*
* Copyright (c) 2002-2014 Eric Lafortune ([email protected])
*
* This program 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 program 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 General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package proguard;
import java.io.File;
import java.util.List;
/**
* The ProGuard configuration.
*
* @see ProGuard
*
* @author Eric Lafortune
*/
public class Configuration
{
public static final File STD_OUT = new File("");
///////////////////////////////////////////////////////////////////////////
// Input and output options.
///////////////////////////////////////////////////////////////////////////
// Android-added: Add -systemjars option.
/**
* A list of system entries (jars, wars, ears, zips, and directories).
*
* <p>A system jar is one that appears on the runtime classpath before the program jars. Unless
* there are duplicate classes between it and a program jar then it behaves no different to a
* library jar. If there are duplicate classes between it and a program jar then the class in
* the system jar will be used and the duplicate class in the program jar will be ignored.
* Conversely, if a library jar contains duplicates of classes in a program jar then the class
* in the program jar will be used and the one in the library jar will be ignored.
*
* <p>e.g. the android.jar from the Android SDK should usually be treated as a system jar
* because at runtime if the APK contains duplicates of classes in android.jar then the ones in
* the APK will be ignored; unless the APK does some ClassLoader manipulation to change that
* behavior.
*/
public ClassPath systemJars;
/**
* A list of input and output entries (jars, wars, ears, zips, and directories).
*/
public ClassPath programJars;
/**
* A list of library entries (jars, wars, ears, zips, and directories).
*/
public ClassPath libraryJars;
/**
* Specifies whether to skip non-public library classes while reading
* library jars.
*/
public boolean skipNonPublicLibraryClasses = false;
/**
* Specifies whether to skip non-public library class members while reading
* library classes.
*/
public boolean skipNonPublicLibraryClassMembers = true;
/**
* A list of <code>String</code>s specifying directories to be kept in
* the output directories or the output jars. A <code>null</code> list
* means no directories. An empty list means all directories. The directory
* names may contain "**", "*", or "?" wildcards, and they may be preceded
* by the "!" negator.
*/
public List keepDirectories;
/**
* Specifies the version number of the output classes, or 0 if the version
* number can be left unchanged.
*/
public int targetClassVersion;
/**
* Specifies the last modification time of this configuration. This time
* is necessary to check whether the input has to be processed. Setting it
* to Long.MAX_VALUE forces processing, even if the modification times
* of the output appear more recent than the modification times of the
* input.
*/
public long lastModified = 0L;
///////////////////////////////////////////////////////////////////////////
// Keep options.
///////////////////////////////////////////////////////////////////////////
/**
* A list of {@link KeepClassSpecification} instances, whose class names and
* class member names are to be kept from shrinking, optimization, and/or
* obfuscation.
*/
public List keep;
/**
* An optional output file for listing the kept seeds.
* An empty file name means the standard output.
*/
public File printSeeds;
///////////////////////////////////////////////////////////////////////////
// Shrinking options.
///////////////////////////////////////////////////////////////////////////
/**
* Specifies whether the code should be shrunk.
*/
public boolean shrink = true;
/**
* An optional output file for listing the unused classes and class
* members. An empty file name means the standard output.
*/
public File printUsage;
/**
* A list of {@link ClassSpecification} instances, for which an explanation
* is to be printed, why they are kept in the shrinking step.
*/
public List whyAreYouKeeping;
///////////////////////////////////////////////////////////////////////////
// Optimization options.
///////////////////////////////////////////////////////////////////////////
/**
* Specifies whether the code should be optimized.
*/
public boolean optimize = true;
/**
* A list of <code>String</code>s specifying the optimizations to be
* performed. A <code>null</code> list means all optimizations. The
* optimization names may contain "*" or "?" wildcards, and they may
* be preceded by the "!" negator.
*/
public List optimizations;
/**
* Specifies the number of optimization passes.
*/
public int optimizationPasses = 1;
/**
* A list of {@link ClassSpecification} instances, whose methods are
* assumed to have no side effects.
*/
public List assumeNoSideEffects;
/**
* Specifies whether the access of class members can be modified.
*/
public boolean allowAccessModification = false;
/**
* Specifies whether interfaces may be merged aggressively.
*/
public boolean mergeInterfacesAggressively = false;
///////////////////////////////////////////////////////////////////////////
// Obfuscation options.
///////////////////////////////////////////////////////////////////////////
/**
* Specifies whether the code should be obfuscated.
*/
public boolean obfuscate = true;
/**
* An optional output file for listing the obfuscation mapping.
* An empty file name means the standard output.
*/
public File printMapping;
/**
* An optional input file for reading an obfuscation mapping.
*/
public File applyMapping;
/**
* An optional name of a file containing obfuscated class member names.
*/
public File obfuscationDictionary;
/**
* An optional name of a file containing obfuscated class names.
*/
public File classObfuscationDictionary;
/**
* An optional name of a file containing obfuscated package names.
*/
public File packageObfuscationDictionary;
/**
* Specifies whether to apply aggressive name overloading on class members.
*/
public boolean overloadAggressively = false;
/**
* Specifies whether to generate globally unique class member names.
*/
public boolean useUniqueClassMemberNames = false;
/**
* Specifies whether obfuscated packages and classes can get mixed-case names.
*/
public boolean useMixedCaseClassNames = true;
/**
* A list of <code>String</code>s specifying package names to be kept.
* A <code>null</code> list means no names. An empty list means all
* names. The package names may contain "**", "*", or "?" wildcards, and
* they may be preceded by the "!" negator.
*/
public List keepPackageNames;
/**
* An optional base package if the obfuscated package hierarchy is to be
* flattened, <code>null</code> otherwise.
*/
public String flattenPackageHierarchy;
/**
* An optional base package if the obfuscated classes are to be repackaged
* into a single package, <code>null</code> otherwise.
*/
public String repackageClasses;
/**
* A list of <code>String</code>s specifying optional attributes to be kept.
* A <code>null</code> list means no attributes. An empty list means all
* attributes. The attribute names may contain "*" or "?" wildcards, and
* they may be preceded by the "!" negator.
*/
public List keepAttributes;
/**
* Specifies whether method parameter names and types should be kept for
* methods that are not obfuscated. This is achieved by keeping partial
* "LocalVariableTable" and "LocalVariableTypeTable" attributes.
*/
public boolean keepParameterNames = false;
/**
* An optional replacement for all SourceFile attributes.
*/
public String newSourceFileAttribute;
/**
* A list of <code>String</code>s specifying a filter for classes whose
* string constants are to be adapted, based on corresponding obfuscated
* class names.
*/
public List adaptClassStrings;
/**
* A list of <code>String</code>s specifying a filter for files whose
* names are to be adapted, based on corresponding obfuscated class names.
*/
public List adaptResourceFileNames;
/**
* A list of <code>String</code>s specifying a filter for files whose
* contents are to be adapted, based on obfuscated class names.
*/
public List adaptResourceFileContents;
///////////////////////////////////////////////////////////////////////////
// Preverification options.
///////////////////////////////////////////////////////////////////////////
/**
* Specifies whether the code should be preverified.
*/
public boolean preverify = true;
/**
* Specifies whether the code should be preverified for Java Micro Edition
* (creating StackMap attributes) instead of for Java Standard Edition
* (creating StackMapTable attributes).
*/
public boolean microEdition = false;
///////////////////////////////////////////////////////////////////////////
// General options.
///////////////////////////////////////////////////////////////////////////
/**
* Specifies whether to print verbose messages.
*/
public boolean verbose = false;
/**
* A list of <code>String</code>s specifying a filter for the classes for
* which not to print notes, if there are noteworthy potential problems.
* A <code>null</code> list means all classes. The class names may contain
* "**", "*", or "?" wildcards, and they may be preceded by the "!" negator.
*/
public List note = null;
/**
* A list of <code>String</code>s specifying a filter for the classes for
* which not to print warnings, if there are any problems.
* A <code>null</code> list means all classes. The class names may contain
* "**", "*", or "?" wildcards, and they may be preceded by the "!" negator.
*/
public List warn = null;
/**
* Specifies whether to ignore any warnings.
*/
public boolean ignoreWarnings = false;
/**
* An optional output file for printing out the configuration that ProGuard
* is using (with included files and replaced variables).
* An empty file name means the standard output.
*/
public File printConfiguration;
/**
* An optional output file for printing out the processed code in a more
* or less readable form. An empty file name means the standard output.
*/
public File dump;
}