aboutsummaryrefslogtreecommitdiffstats
path: root/examples/gradle/retrace.gradle
diff options
context:
space:
mode:
Diffstat (limited to 'examples/gradle/retrace.gradle')
-rw-r--r--examples/gradle/retrace.gradle64
1 files changed, 64 insertions, 0 deletions
diff --git a/examples/gradle/retrace.gradle b/examples/gradle/retrace.gradle
new file mode 100644
index 0000000..7fe2c7e
--- /dev/null
+++ b/examples/gradle/retrace.gradle
@@ -0,0 +1,64 @@
+//
+// 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[]); \
+ }'
+}