普通文本  |  65行  |  1.89 KB

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