// // This Gradle build file illustrates how to process J2ME midlets. // Usage: // gradle -b midlets.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. injars 'in.jar' outjars 'out.jar' libraryjars '/usr/local/java/wtk2.5.2/lib/midpapi20.jar' libraryjars '/usr/local/java/wtk2.5.2/lib/cldcapi11.jar' // Preverify the code suitably for Java Micro Edition. microedition // 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 // On Windows, you can't use mixed case class names, // should you still want to use the preverify tool. // // dontusemixedcaseclassnames // Save the obfuscation mapping to a file, so you can de-obfuscate any stack // traces later on. printmapping 'out.map' // You can keep a fixed source file attribute and all line number tables to // get stack traces with line numbers. //renamesourcefileattribute 'SourceFile' //keepattributes 'SourceFile,LineNumberTable' // You can print out the seeds that are matching the keep options below. //printseeds 'out.seeds' // Preserve all public midlets. keep 'public class * extends javax.microedition.midlet.MIDlet' // Preserve all native method names and the names of their classes. keepclasseswithmembernames includedescriptorclasses:true, 'class * { \ native <methods>; \ }' // Your midlet may contain more items that need to be preserved; // typically classes that are dynamically created using Class.forName: // keep 'public class mypackage.MyClass' // keep 'public interface mypackage.MyInterface' // keep 'public class * implements mypackage.MyInterface' }