2013-12-18 12 views
14

Właśnie zbudowałem pakiet APK, używając Gradle do wydania (ProGuard 4.9 i podpisane). Kiedy uruchomić awarii app go na ten błąd:Wydanie Androida awarii APK z java.lang.AssertionError: impossible in java.lang.Enum

E/AndroidRuntime(8662): java.lang.AssertionError: impossible 
E/AndroidRuntime(8662): at java.lang.Enum$1.create(Enum.java:44) 
E/AndroidRuntime(8662): at java.lang.Enum$1.create(Enum.java:35) 
E/AndroidRuntime(8662): at libcore.util.BasicLruCache.get(BasicLruCache.java:54) 
E/AndroidRuntime(8662): at java.lang.Enum.getSharedConstants(Enum.java:210) 
E/AndroidRuntime(8662): at java.lang.Enum.valueOf(Enum.java:190) 
E/AndroidRuntime(8662): at kr.infli.s.Z(Inflikr.java:390) 
E/AndroidRuntime(8662): at kr.infli.a.ev(Inflikr.java:409) 
E/AndroidRuntime(8662): at kr.infli.activity.InflikrActivity.onResume(InflikrActivity.java:231) 
E/AndroidRuntime(8662): at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1192) 
E/AndroidRuntime(8662): at android.app.Activity.performResume(Activity.java:5310) 
E/AndroidRuntime(8662): at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2778) 
E/AndroidRuntime(8662): at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2817) 
E/AndroidRuntime(8662): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2250) 
E/AndroidRuntime(8662): at android.app.ActivityThread.access$800(ActivityThread.java:135) 
E/AndroidRuntime(8662): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
E/AndroidRuntime(8662): at android.os.Handler.dispatchMessage(Handler.java:102) 
E/AndroidRuntime(8662): at android.os.Looper.loop(Looper.java:136) 
E/AndroidRuntime(8662): at android.app.ActivityThread.main(ActivityThread.java:5017) 
E/AndroidRuntime(8662): at java.lang.reflect.Method.invoke(Native Method) 
E/AndroidRuntime(8662): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
E/AndroidRuntime(8662): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
E/AndroidRuntime(8662): Caused by: java.lang.NoSuchMethodException: values [] 
E/AndroidRuntime(8662): at java.lang.Class.getMethod(Class.java:661) 
E/AndroidRuntime(8662): at java.lang.Class.getDeclaredMethod(Class.java:623) 
E/AndroidRuntime(8662): at java.lang.Enum$1.create(Enum.java:41) 
E/AndroidRuntime(8662): ... 20 more 

Wygląda tego błędu nie powinno się zdarzyć: https://android.googlesource.com/platform/libcore/+/9edf43dfcc35c761d97eb9156ac4254152ddbc55/libdvm/src/main/java/java/lang/Enum.java

Moja build.gradle zawiera:

buildTypes { 
    release { 
     runProguard true 
     proguardFile file('./proguard-project.txt') 
     signingConfig signingConfigs.release 
    } 
} 

Moje PROGUARD-project.txt zawiera

Po usunięciu ProGuard z build.gradle nie ulega awarii.

Kiedy korzystałem z ProGuarda z kompilacji Anta, zadziałało (niedawno przeprowadziłem migrację do Gradle).

Dowolny znany problem z Gradle + ProGuard?

Dzięki

Odpowiedz

24

Trzeba powiedzieć ProGuard zachować jakieś enum metod.

Android narzędzi SDK tej konfiguracji PROGUARD aby go osiągnąć:

# For enumeration classes, see http://proguard.sourceforge.net/manual/examples.html#enumerations 
-keepclassmembers enum * { 
    public static **[] values(); 
    public static ** valueOf(java.lang.String); 
} 

Można dodać powyższą regułę do konfiguracji PROGUARD czy można (co wolałbym) zawierają domyślne Android zasad:

runProguard true 
proguardFile getDefaultProguardFile('proguard-android.txt') 
proguardFile file('./proguard-project.txt') 
+0

wygląda 'metoda runProguard' nie ma, więc po prostu łączy swoje dwie linie do' proguardFiles getDefaultProguardFile ('PROGUARD-android.txt'), plików ("PROGUARD-rules.txt") ' –

+3

@ DraškoKokić: nazwa 'runProguard' została zmieniona na' minifyEnabled' w [Android Gradle plugin 1.0.0] (http://tools.android.com/tech-docs/new-build-system/migrating-to-1-0-0). (Musisz podać 'minifyEnabled true' dla swojego typu kompilacji wydania, w przeciwnym razie ProGuard * nie * będzie uruchamiany.) – Jonik