aboutsummaryrefslogtreecommitdiffstats
path: root/examples/gradle/proguardall.gradle
diff options
context:
space:
mode:
Diffstat (limited to 'examples/gradle/proguardall.gradle')
-rw-r--r--examples/gradle/proguardall.gradle93
1 files changed, 93 insertions, 0 deletions
diff --git a/examples/gradle/proguardall.gradle b/examples/gradle/proguardall.gradle
new file mode 100644
index 0000000..561a455
--- /dev/null
+++ b/examples/gradle/proguardall.gradle
@@ -0,0 +1,93 @@
+//
+// This Gradle build file illustrates how to process ProGuard
+// (including its main application, its GUI, its Ant task, and its WTK plugin),
+// and the ReTrace tool, all in one go.
+// Configuration files for typical applications will be very similar.
+// Usage:
+// gradle -b proguardall.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.
+ // We'll read all jars from the lib directory, process them, and write the
+ // processed jars to a new out directory.
+
+ injars '../../lib'
+ outjars 'out'
+
+ // You may have to adapt the paths below.
+
+ libraryjars "${System.getProperty('java.home')}/lib/rt.jar"
+ libraryjars '/usr/local/java/ant/lib/ant.jar'
+ libraryjars '/usr/local/java/gradle-1.3/lib/plugins/gradle-plugins-1.3.jar'
+ libraryjars '/usr/local/java/gradle-1.3/lib/gradle-base-services-1.3.jar'
+ libraryjars '/usr/local/java/gradle-1.3/lib/gradle-core-1.3.jar'
+ libraryjars '/usr/local/java/gradle-1.3/lib/groovy-all-1.8.6.jar'
+ libraryjars '/usr/local/java/wtk2.5.2/wtklib/kenv.zip'
+
+ // 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 ''
+
+ // Adapt the names and contents of the resource files.
+
+ adaptresourcefilenames '**.properties,**.gif,**.jpg'
+ adaptresourcefilecontents 'proguard/ant/task.properties'
+
+ // The main entry points.
+
+ keep 'public class proguard.ProGuard { \
+ public static void main(java.lang.String[]); \
+ }'
+
+ keep 'public class proguard.gui.ProGuardGUI { \
+ public static void main(java.lang.String[]); \
+ }'
+
+ keep 'public class proguard.retrace.ReTrace { \
+ public static void main(java.lang.String[]); \
+ }'
+
+ // If we have ant.jar, we can properly process the Ant task.
+
+ keep allowobfuscation: true, 'class proguard.ant.*'
+ keepclassmembers 'public class proguard.ant.* { \
+ <init>(org.apache.tools.ant.Project); \
+ public void set*(***); \
+ public void add*(***); \
+ }'
+
+ // If we have the Gradle jars, we can properly process the Gradle task.
+
+ keep 'public class proguard.gradle.* { \
+ public *; \
+ }'
+
+ // If we have kenv.zip, we can process the J2ME WTK plugin.
+
+ keep 'public class proguard.wtk.ProGuardObfuscator'
+}