// // 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[]); \ }' }