Skip to main content
Oldes
Inspiring
December 5, 2016
Question

Android ANE - unable to find class android/support/v4/app/FragmentActivity

  • December 5, 2016
  • 0 replies
  • 380 views

Hi,

I have app with target SDK 24 and own ANE for Google Play services, but it seems to fail to init on Android 4.4 with these lines in log:

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY: unable to find class referenced in signature (Landroid/support/v4/app/FragmentActivity;)

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY: Ljava/lang/Object; is not instance of Landroid/app/Activity;

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY: bad arg 1 (into Landroid/app/Activity;)

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY:  rejecting call to Lcom/google/android/gms/internal/zzqi;.<init> (Landroid/app/Activity;)V

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY:  rejecting opcode 0x70 at 0x0002

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: VFY:  rejected Lcom/google/android/gms/common/api/GoogleApiClient$Builder;.enableAutoManage (Landroid/support/v4/app/FragmentActivity;ILcom/google/android/gms/common/api/GoogleApiClient$OnConnectionFailedListener;)Lcom/google/android/gms/common/api/GoogleApiClient$Builder;

12-05 12:14:30.209 7930-7930/com.amanitadesign.TestAndroidGooglePlayANE W/dalvikvm: Verifier rejected class Lcom/google/android/gms/common/api/GoogleApiClient$Builder;

The code for android/support/v4/ is part of AIR runtime, so what I should do to get it working?

I was trying to include android-support-v4.jar as a package dependency, but than app packaging fails with errors like:

dx tool failed:

UNEXPECTED TOP-LEVEL EXCEPTION:

java.lang.IllegalArgumentException: already added: Landroid/support/v4/view/LayoutInflaterCompatBase$FactoryWrapper;

        at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122)

        at com.android.dx.dex.file.DexFile.add(DexFile.java:161)

        at com.android.dx.command.dexer.Main.processClass(Main.java:737)

        at com.android.dx.command.dexer.Main.processFileBytes(Main.java:678)

        at com.android.dx.command.dexer.Main.access$300(Main.java:83)

        at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:607)

        at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)

        at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)

        at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)

        at com.android.dx.command.dexer.Main.processOne(Main.java:637)

        at com.android.dx.command.dexer.Main.processAllFiles(Main.java:511)

        at com.android.dx.command.dexer.Main.runMonoDex(Main.java:281)

        at com.android.dx.command.dexer.Main.run(Main.java:247)

        at com.android.dx.command.dexer.Main.main(Main.java:215)

        at com.android.dx.command.Main.main(Main.java:106)

1 error; aborting

Note that this is just test app so no other ANEs are used so this is not a case of this duplicity.

Any help?

Thanks,

David

PS: source code is here: GitHub - Oldes/ANEAndroidGooglePlay

This topic has been closed for replies.