//
// This Gradle build file illustrates how to process the ReTrace tool.
// Configuration files for typical applications will be very similar.
// Usage:
// gradle -b retrace.gradle proguard
//
// Tell Gradle where to find the ProGuard task.
buildscript {
repositories {
flatDir dirs: '../../lib'
}
dependencies {
classpath ':proguard'
}
}
// Define a ProGuard task.
task proguard(type: proguard.gradle.ProGuardTask) {
// You should probably import a more compact ProGuard-style configuration
// file for all static settings, but we're specifying them all here, for
// the sake of the example.
//configuration 'configuration.pro'
// Specify the input jars, output jars, and library jars.
// The input jars will be merged in a single output jar.
// We'll filter out the Ant and WTK classes.
injars '../../lib/retrace.jar'
injars '../../lib/proguard.jar(!META-INF/MANIFEST.MF,'
!proguard/ant/**,!proguard/wtk/**)
outjars 'retrace_out.jar'
libraryjars "${System.getProperty('java.home')}/lib/rt.jar"
// If we wanted to reuse the previously obfuscated proguard_out.jar, we could
// perform incremental obfuscation based on its mapping file, and only keep the
// additional ReTrace files instead of all files.
//applymapping 'proguard.map'
//outjars 'retrace_out.jar', filter: 'proguard/retrace/**'
// Allow methods with the same signature, except for the return type,
// to get the same obfuscation name.
overloadaggressively
// Put all obfuscated classes into the nameless root package.
repackageclasses ''
// Allow classes and class members to be made public.
allowaccessmodification
// The entry point: ReTrace and its main method.
keep 'public class proguard.retrace.ReTrace { \
public static void main(java.lang.String[]); \
}'
}