зеркало из https://github.com/mozilla/gecko-dev.git
176 строки
5.2 KiB
Plaintext
176 строки
5.2 KiB
Plaintext
# Modified from https://robotsandpencils.com/blog/use-proguard-android-library/.
|
|
|
|
# Preserve all annotations.
|
|
|
|
-keepattributes *Annotation*
|
|
|
|
# Preserve all public classes, and their public and protected fields and
|
|
# methods.
|
|
|
|
-keep public class * {
|
|
static public protected *;
|
|
}
|
|
|
|
# Preserve all .class method names.
|
|
|
|
-keepclassmembernames class * {
|
|
java.lang.Class class$(java.lang.String);
|
|
java.lang.Class class$(java.lang.String, boolean);
|
|
}
|
|
|
|
# Preserve all native method names and the names of their classes.
|
|
|
|
-keepclasseswithmembernames class * {
|
|
native <methods>;
|
|
}
|
|
|
|
# Preserve the special static methods that are required in all enumeration
|
|
# classes.
|
|
|
|
-keepclassmembers class * extends java.lang.Enum {
|
|
public static **[] values();
|
|
public static ** valueOf(java.lang.String);
|
|
}
|
|
|
|
# Explicitly preserve all serialization members. The Serializable interface
|
|
# is only a marker interface, so it wouldn't save them.
|
|
# You can comment this out if your library doesn't use serialization.
|
|
# If your code contains serializable classes that have to be backward
|
|
# compatible, please refer to the manual.
|
|
|
|
-keepclassmembers class * implements java.io.Serializable {
|
|
static final long serialVersionUID;
|
|
static final java.io.ObjectStreamField[] serialPersistentFields;
|
|
private void writeObject(java.io.ObjectOutputStream);
|
|
private void readObject(java.io.ObjectInputStream);
|
|
java.lang.Object writeReplace();
|
|
java.lang.Object readResolve();
|
|
}
|
|
|
|
# Preserve all View implementations and their special context constructors.
|
|
|
|
-keep public class * extends android.view.View {
|
|
public <init>(android.content.Context);
|
|
public <init>(android.content.Context, android.util.AttributeSet);
|
|
public <init>(android.content.Context, android.util.AttributeSet, int);
|
|
public void set*(...);
|
|
}
|
|
|
|
# Keep setters in Views so that animations can still work.
|
|
# See http://proguard.sourceforge.net/manual/examples.html#beans
|
|
# From tools/proguard/proguard-android.txt.
|
|
-keepclassmembers public class * extends android.view.View {
|
|
void set*(***);
|
|
*** get*();
|
|
}
|
|
|
|
# Preserve all classes that have special context constructors, and the
|
|
# constructors themselves.
|
|
|
|
-keepclasseswithmembers class * {
|
|
public <init>(android.content.Context, android.util.AttributeSet);
|
|
}
|
|
|
|
# Preserve the special fields of all Parcelable implementations.
|
|
|
|
-keepclassmembers class * implements android.os.Parcelable {
|
|
static android.os.Parcelable$Creator CREATOR;
|
|
}
|
|
|
|
# Preserve static fields of inner classes of R classes that might be accessed
|
|
# through introspection.
|
|
|
|
-keepclassmembers class **.R$* {
|
|
public static <fields>;
|
|
}
|
|
|
|
# GeckoView specific rules.
|
|
|
|
# Keep classes, and all their contents, compiled before annotation.*.
|
|
-keep class org.mozilla.gecko.AppConstants {
|
|
*;
|
|
}
|
|
-keep class org.mozilla.gecko.AppConstants$Versions {
|
|
*;
|
|
}
|
|
-keep class org.mozilla.gecko.SysInfo {
|
|
*;
|
|
}
|
|
|
|
# Keep the annotation.
|
|
-keep @interface org.mozilla.gecko.annotation.JNITarget
|
|
|
|
# Keep classes tagged with the annotation.
|
|
-keep @org.mozilla.gecko.annotation.JNITarget class *
|
|
|
|
# Keep all members of an annotated class.
|
|
-keepclassmembers @org.mozilla.gecko.annotation.JNITarget class * {
|
|
*;
|
|
}
|
|
|
|
# Keep annotated members of any class.
|
|
-keepclassmembers class * {
|
|
@org.mozilla.gecko.annotation.JNITarget *;
|
|
}
|
|
|
|
# Keep classes which contain at least one annotated element. Split over two directives
|
|
# because, according to the developer of ProGuard, "the option -keepclasseswithmembers
|
|
# doesn't combine well with the '*' wildcard" (And, indeed, using it causes things to
|
|
# be deleted that we want to keep.)
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.JNITarget <methods>;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.JNITarget <fields>;
|
|
}
|
|
|
|
# Keep WebRTC targets.
|
|
-keep @interface org.mozilla.gecko.annotation.WebRTCJNITarget
|
|
-keep @org.mozilla.gecko.annotation.WebRTCJNITarget class *
|
|
-keepclassmembers class * {
|
|
@org.mozilla.gecko.annotation.WebRTCJNITarget *;
|
|
}
|
|
-keepclassmembers @org.mozilla.gecko.annotation.WebRTCJNITarget class * {
|
|
*;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.WebRTCJNITarget <methods>;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.WebRTCJNITarget <fields>;
|
|
}
|
|
|
|
# Keep generator-targeted entry points.
|
|
-keep @interface org.mozilla.gecko.annotation.WrapForJNI
|
|
-keep @org.mozilla.gecko.annotation.WrapForJNI class *
|
|
-keepclassmembers class * {
|
|
@org.mozilla.gecko.annotation.WrapForJNI *;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.WrapForJNI <methods>;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.WrapForJNI <fields>;
|
|
}
|
|
|
|
# Keep all members of an annotated class.
|
|
-keepclassmembers @org.mozilla.gecko.annotation.WrapForJNI class * {
|
|
*;
|
|
}
|
|
|
|
# Keep Reflection targets.
|
|
-keep @interface org.mozilla.gecko.annotation.ReflectionTarget
|
|
-keep @org.mozilla.gecko.annotation.ReflectionTarget class *
|
|
-keepclassmembers class * {
|
|
@org.mozilla.gecko.annotation.ReflectionTarget *;
|
|
}
|
|
-keepclassmembers @org.mozilla.gecko.annotation.ReflectionTarget class * {
|
|
*;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.ReflectionTarget <methods>;
|
|
}
|
|
-keepclasseswithmembers class * {
|
|
@org.mozilla.gecko.annotation.ReflectionTarget <fields>;
|
|
}
|