I'm refactoring an app to use androidx. I have struggled to get rid of all the libraries that do not support it. I thought I had removed all the libraries that use the support libraries but it looks like there is still something that is importing it. I now get the error:
AGPBI: {"kind":"error","text":"Program type already present: android.support.v4.os.ResultReceiver$MyResultReceiver","sources":[{}],"tool":"D8"} java.lang.RuntimeException: java.lang.RuntimeException: com.android.builder.dexing.DexArchiveMergerException: Error while merging dex archives: /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/532, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/0.jar, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/1.jar,
...
/Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/530.jar, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/531.jar Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes. Program type already present: android.support.v4.os.ResultReceiver$MyResultReceiver at sun.reflect.GeneratedConstructorAccessor377.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:423) at java.util.concurrent.ForkJoinTask.getThrowableException(ForkJoinTask.java:593) at java.util.concurrent.ForkJoinTask.reportException(ForkJoinTask.java:677) ... at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:46) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:55) at java.lang.Thread.run(Thread.java:745) Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes. Program type already present: android.support.v4.os.ResultReceiver$MyResultReceiver at java.util.concurrent.ForkJoinTask$AdaptedCallable.exec(ForkJoinTask.java:1431) at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1692) at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157) Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes. Program type already present: android.support.v4.os.ResultReceiver$MyResultReceiver at com.android.builder.dexing.D8DexArchiveMerger.getExceptionToRethrow(D8DexArchiveMerger.java:129) at com.android.builder.dexing.D8DexArchiveMerger.mergeDexArchives(D8DexArchiveMerger.java:114) at com.android.build.gradle.internal.transforms.DexMergerTransformCallable.call(DexMergerTransformCallable.java:101) at com.android.build.gradle.internal.transforms.DexMergerTransformCallable.call(DexMergerTransformCallable.java:36) at java.util.concurrent.ForkJoinTask$AdaptedCallable.exec(ForkJoinTask.java:1424) ... 4 more at com.android.tools.r8.utils.ExceptionUtils.withCompilationHandler(ExceptionUtils.java:71) at com.android.tools.r8.utils.ExceptionUtils.withD8CompilationHandler(ExceptionUtils.java:41) at com.android.tools.r8.D8.run(D8.java:89) at com.android.builder.dexing.D8DexArchiveMerger.mergeDexArchives(D8DexArchiveMerger.java:112) ... 7 more at com.android.tools.r8.utils.Reporter.failIfPendingErrors(Reporter.java:83) at com.android.tools.r8.utils.Reporter.fatalError(Reporter.java:62) at com.android.tools.r8.utils.ExceptionUtils.withCompilationHandler(ExceptionUtils.java:62) ... 10 more :app:transformDexArchiveWithDexMergerForDebug FAILED FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':app:transformDexArchiveWithDexMergerForDebug'.
com.android.build.api.transform.TransformException: java.lang.RuntimeException: java.lang.RuntimeException: com.android.builder.dexing.DexArchiveMergerException: Error while merging dex archives: /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/532, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/0.jar, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/1.jar,
...
/Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/530.jar, /Users/name/myproject/app/build/intermediates/transforms/dexBuilder/debug/531.jar Learn how to resolve the issue at https://developer.android.com/studio/build/dependencies#duplicate_classes. Program type already present: android.support.v4.os.ResultReceiver$MyResultReceiver
Running ./gradlew androidDependencies
and I get:
debugCompileClasspath - Dependencies for compilation +--- io.realm:realm-android-library:5.1.0@aar +--- io.realm:realm-android-kotlin-extensions:5.1.0@aar +--- io.realm:realm-annotations:5.1.0@jar +--- javax.annotation:jsr250-api:1.0@jar +--- com.google.dagger:dagger-android:2.16@aar +--- androidx.preference:preference:1.0.0-alpha1@aar +--- com.google.android.material:material:1.0.0-alpha1@aar +--- androidx.appcompat:appcompat:1.0.0-alpha1@aar +--- androidx.cardview:cardview:1.0.0-alpha1@aar +--- androidx.recyclerview:recyclerview:1.0.0-alpha1@aar +--- androidx.gridlayout:gridlayout:1.0.0-alpha1@aar +--- androidx.legacy:legacy-support-v4:1.0.0-alpha1@aar +--- androidx.vectordrawable:vectordrawable-animated:1.0.0-alpha1@aar +--- androidx.vectordrawable:vectordrawable:1.0.0-alpha1@aar +--- androidx.palette:palette:1.0.0-alpha1@aar +--- com.firebaseui:firebase-ui-auth:3.1.0@aar +--- com.google.firebase:firebase-auth:15.0.0@aar +--- com.google.firebase:firebase-config:15.0.2@aar +--- com.google.firebase:firebase-database:15.0.1@aar +--- com.jakewharton.rxbinding2:rxbinding:2.0.0@aar +--- com.jakewharton.rxrelay2:rxrelay:2.0.0@jar +--- joda-time:joda-time:2.5@jar +--- com.jakewharton.timber:timber:4.3.1@aar +--- com.uncopt:android.justified:1.0@jar +--- androidx.lifecycle:lifecycle-common-java8:2.0.0-alpha1@jar +--- androidx.lifecycle:lifecycle-extensions:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-reactivestreams:2.0.0-alpha1@aar +--- com.squareup.retrofit2:adapter-rxjava2:2.2.0@jar +--- com.squareup.retrofit2:converter-moshi:2.2.0@jar +--- com.squareup.retrofit2:converter-scalars:2.2.0@jar +--- com.squareup.retrofit2:retrofit:2.2.0@jar +--- com.squareup.okhttp3:okhttp-urlconnection:3.4.1@jar +--- com.squareup.okhttp3:logging-interceptor:3.4.1@jar +--- com.github.franmontiel:PersistentCookieJar:v1.0.1@aar +--- com.squareup.okhttp3:okhttp:3.6.0@jar +--- com.squareup.moshi:moshi-kotlin:1.5.0@jar +--- com.github.MFlisar:RxBus2:0.1@aar +--- com.jakewharton:butterknife:8.8.1@aar +--- com.squareup.leakcanary:leakcanary-android:1.5.1@aar +--- com.crashlytics.sdk.android:crashlytics:2.6.8@aar +--- com.f2prateek.rx.preferences2:rx-preferences:2.0.0-RC2@aar +--- org.jetbrains.kotlin:kotlin-stdlib-jdk7:1.2.41@jar +--- org.jetbrains.kotlin:kotlin-android-extensions-runtime:1.2.41@jar +--- com.google.code.findbugs:jsr305:1.3.9@jar +--- com.getkeepsafe.relinker:relinker:1.2.2@aar +--- com.google.dagger:dagger:2.16@jar +--- com.android.support:customtabs:26.1.0@aar +--- com.android.support:cardview-v7:26.1.0@aar +--- com.jakewharton:butterknife-annotations:8.8.1@jar +--- com.android.support:design:26.1.0@aar +--- com.android.support:appcompat-v7:26.1.0@aar +--- com.android.support:recyclerview-v7:26.1.0@aar +--- com.android.support:transition:26.1.0@aar +--- com.google.firebase:firebase-abt:15.0.1@aar +--- com.google.firebase:firebase-database-connection:15.0.1@aar +--- com.google.firebase:firebase-analytics:15.0.2@aar +--- com.google.firebase:firebase-analytics-impl:15.0.2@aar +--- com.google.firebase:firebase-iid:15.1.0@aar +--- com.google.firebase:firebase-common:15.0.1@aar +--- com.google.android.gms:play-services-phenotype:15.0.1@aar +--- com.google.firebase:firebase-database-collection:15.0.1@aar +--- com.google.android.gms:play-services-auth:11.4.2@aar +--- com.google.android.gms:play-services-ads-identifier:15.0.1@aar +--- com.google.android.gms:play-services-stats:15.0.1@aar +--- com.google.firebase:firebase-iid-interop:15.0.0@aar +--- com.google.android.gms:play-services-auth-api-phone:11.4.2@aar +--- com.google.android.gms:play-services-auth-base:11.4.2@aar +--- com.google.android.gms:play-services-flags:15.0.1@aar +--- com.google.android.gms:play-services-base:15.0.1@aar +--- com.google.android.gms:play-services-tasks:15.0.1@aar +--- com.google.android.gms:play-services-basement:15.0.1@aar +--- com.android.support:support-v4:26.1.0@aar +--- com.android.support:support-media-compat:26.1.0@aar +--- com.android.support:support-fragment:26.1.0@aar +--- com.android.support:support-core-utils:26.1.0@aar +--- com.android.support:animated-vector-drawable:26.1.0@aar +--- com.android.support:support-core-ui:26.1.0@aar +--- com.android.support:support-vector-drawable:26.1.0@aar +--- com.android.support:support-compat:26.1.0@aar +--- com.android.support:support-annotations:26.1.0@jar +--- javax.inject:javax.inject:1@jar +--- androidx.fragment:fragment:1.0.0-alpha1@aar +--- androidx.legacy:legacy-support-core-ui:1.0.0-alpha1@aar +--- androidx.legacy:legacy-support-core-utils:1.0.0-alpha1@aar +--- androidx.media:media:1.0.0-alpha1@aar +--- androidx.transition:transition:1.0.0-alpha1@aar +--- androidx.loader:loader:1.0.0-alpha1@aar +--- androidx.viewpager:viewpager:1.0.0-alpha1@aar +--- androidx.coordinatorlayout:coordinatorlayout:1.0.0-alpha1@aar +--- androidx.drawerlayout:drawerlayout:1.0.0-alpha1@aar +--- androidx.slidingpanelayout:slidingpanelayout:1.0.0-alpha1@aar +--- androidx.customview:customview:1.0.0-alpha1@aar +--- androidx.swiperefreshlayout:swiperefreshlayout:1.0.0-alpha1@aar +--- androidx.asynclayoutinflater:asynclayoutinflater:1.0.0-alpha1@aar +--- androidx.core:core:1.0.0-alpha1@aar +--- androidx.collection:collection:1.0.0-alpha1@jar +--- androidx.cursoradapter:cursoradapter:1.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-process:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-service:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-runtime:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-livedata:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-livedata-core:2.0.0-alpha1@aar +--- androidx.lifecycle:lifecycle-common:2.0.0-alpha1@jar +--- androidx.arch.core:core-runtime:2.0.0-alpha1@aar +--- androidx.arch.core:core-common:2.0.0-alpha1@jar +--- androidx.lifecycle:lifecycle-viewmodel:2.0.0-alpha1@aar +--- androidx.documentfile:documentfile:1.0.0-alpha1@aar +--- androidx.localbroadcastmanager:localbroadcastmanager:1.0.0-alpha1@aar +--- androidx.print:print:1.0.0-alpha1@aar +--- androidx.interpolator:interpolator:1.0.0-alpha1@aar +--- androidx.annotation:annotation:1.0.0-alpha1@jar +--- com.android.support.constraint:constraint-layout:1.1.0-beta1@aar +--- com.github.akarnokd:rxjava2-extensions:0.15.2@jar +--- io.reactivex.rxjava2:rxandroid:2.0.1@aar +--- io.reactivex.rxjava2:rxjava:2.0.6@jar +--- org.reactivestreams:reactive-streams:1.0.0@jar +--- com.squareup.moshi:moshi:1.5.0@jar +--- org.jetbrains.kotlin:kotlin-reflect:1.1.1@jar +--- org.jetbrains.kotlin:kotlin-stdlib:1.2.41@jar +--- com.squareup.leakcanary:leakcanary-analyzer:1.5.1@jar +--- com.crashlytics.sdk.android:beta:1.2.5@aar +--- com.crashlytics.sdk.android:crashlytics-core:2.3.17@aar +--- com.crashlytics.sdk.android:answers:1.3.13@aar +--- io.fabric.sdk.android:fabric:1.3.17@aar +--- com.google.android.gms:play-services-measurement-base:15.0.2@aar +--- com.android.support.constraint:constraint-layout-solver:1.1.0-beta1@jar +--- com.google.android.gms:play-services-auth-license:11.4.2@aar +--- com.squareup.haha:haha:2.0.3@jar +--- com.squareup.leakcanary:leakcanary-watcher:1.5.1@jar +--- com.google.android.gms:play-services-auth-api-phone-license:11.4.2@aar +--- com.google.android.gms:play-services-auth-base-license:11.4.2@aar +--- com.squareup.okio:okio:1.13.0@jar +--- org.jetbrains:annotations:13.0@jar +--- android.arch.lifecycle:runtime:1.0.0@aar +--- android.arch.lifecycle:common:1.0.0@jar \--- android.arch.core:common:1.0.0@jar
The question is: is there a way for me to know which dependency is importing the support library apart from checking the build.gradle
:
buildscript { repositories { maven { url 'https://maven.fabric.io/public' } mavenCentral() google() } dependencies { classpath 'io.fabric.tools:gradle:1.25.4' } } repositories { mavenCentral() maven { url 'https://maven.fabric.io/public' } maven { url 'https://maven.google.com' } } apply plugin: 'com.android.application' apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' apply plugin: 'kotlin-kapt' apply plugin: 'io.fabric' apply plugin: 'realm-android' android { def versionMajor = 0 def versionMinor = 1 def versionPatch = 0 compileSdkVersion 'android-P' compileOptions { targetCompatibility JavaVersion.VERSION_1_8 sourceCompatibility JavaVersion.VERSION_1_8 defaultConfig { applicationId "org.appid" versionName "${versionMajor}.${versionMinor}.${versionPatch}" versionCode versionMajor * 10000 + versionMinor * 100 + versionPatch minSdkVersion 19 targetSdkVersion 27 dexOptions { preDexLibraries = false javaMaxHeapSize "4g" } } } buildTypes { release { debuggable false minifyEnabled true zipAlignEnabled true renderscriptDebuggable false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' signingConfig signingConfigs.release javaCompileOptions.annotationProcessorOptions.arguments['butterknife.debuggable'] = 'false' resValue "string", "app_version", "${defaultConfig.versionName}" } debug { versionNameSuffix "_dev" resValue "string", "app_version", "${defaultConfig.versionName}${versionNameSuffix}" debuggable true signingConfig signingConfigs.debug minifyEnabled false } } } def jsr250_api = '1.0' def androidxVersion = '1.0.0-alpha1' def lifecycle_runtime = '2.0.0-alpha1' def daggerVer = '2.16' def rxbinding = '2.0.0' def rxbus2 = '0.1' def retrofit2 = '2.2.0' def okhttp3 = '3.4.1' def firebase = '15.0.0' def firebase_database = '15.0.1' def firebaseConfig = '15.0.2' def firebase_ui_auth = '3.1.0' def butter_knife = '8.8.1' def leak_canary = '1.5.1' def persistent_cookie_jar = 'v1.0.1' def joda_time = '2.5' def timber = '4.3.1' def justified_text_view = '1.0' def crashlytics = '2.6.8@aar' def hamcrestVersion = '1.3' def espresso_core = '3.1.0-alpha1' def mockitoKotlinVersion = '1.5.0' def mockitoKotlinInlineVersion = '2.13.0' // to allow testing final classes def junit = '4.12' dependencies { kapt "com.google.dagger:dagger-android-processor:$daggerVer" implementation "com.google.dagger:dagger-android:$daggerVer" kapt "com.google.dagger:dagger-compiler:$daggerVer" implementation "androidx.appcompat:appcompat:$androidxVersion" implementation "androidx.cardview:cardview:$androidxVersion" implementation "androidx.recyclerview:recyclerview:$androidxVersion" implementation "androidx.gridlayout:gridlayout:$androidxVersion" implementation "androidx.preference:preference:$androidxVersion" implementation "androidx.vectordrawable:vectordrawable:$androidxVersion" implementation "androidx.palette:palette:$androidxVersion" implementation "com.google.android.material:material:$androidxVersion" implementation "com.google.firebase:firebase-auth:$firebase" implementation "com.google.firebase:firebase-config:$firebaseConfig" implementation "com.google.firebase:firebase-database:$firebase_database" implementation "com.firebaseui:firebase-ui-auth:$firebase_ui_auth" implementation "com.jakewharton.rxbinding2:rxbinding:$rxbinding" implementation "com.jakewharton.rxrelay2:rxrelay:$rxbinding" implementation "joda-time:joda-time:$joda_time" implementation "com.jakewharton.timber:timber:$timber" implementation "com.uncopt:android.justified:$justified_text_view" implementation "androidx.lifecycle:lifecycle-common-java8:$lifecycle_runtime" kapt "androidx.lifecycle:lifecycle-compiler:$lifecycle_runtime" implementation "androidx.lifecycle:lifecycle-extensions:$lifecycle_runtime" testImplementation "androidx.arch.core:core-testing:$lifecycle_runtime" //To use LiveData with ReactiveStreams API implementation "androidx.lifecycle:lifecycle-reactivestreams:$lifecycle_runtime" implementation "com.squareup.retrofit2:retrofit:$retrofit2" implementation "com.squareup.retrofit2:adapter-rxjava2:$retrofit2" implementation "com.squareup.retrofit2:converter-moshi:$retrofit2" implementation "com.squareup.retrofit2:converter-scalars:$retrofit2" implementation "com.squareup.okhttp3:okhttp:$okhttp3" implementation "com.squareup.okhttp3:okhttp-urlconnection:$okhttp3" implementation "com.squareup.okhttp3:logging-interceptor:$okhttp3" implementation "com.github.franmontiel:PersistentCookieJar:$persistent_cookie_jar" implementation 'com.squareup.moshi:moshi-kotlin:1.5.0' implementation "com.github.MFlisar:RxBus2:$rxbus2" kapt "com.jakewharton:butterknife-compiler:$butter_knife" implementation "com.jakewharton:butterknife:$butter_knife" implementation "com.squareup.leakcanary:leakcanary-android:$leak_canary" releaseImplementation "com.squareup.leakcanary:leakcanary-android-no-op:$leak_canary" testImplementation "com.squareup.leakcanary:leakcanary-android-no-op:$leak_canary" compileOnly "javax.annotation:jsr250-api:$jsr250_api" implementation("com.crashlytics.sdk.android:crashlytics:$crashlytics") { transitive = true } implementation 'com.f2prateek.rx.preferences2:rx-preferences:2.0.0-RC2' implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" testImplementation "junit:junit:$junit" testImplementation "com.nhaarman:mockito-kotlin:$mockitoKotlinVersion" testImplementation "org.mockito:mockito-inline:$mockitoKotlinInlineVersion" testImplementation "org.hamcrest:hamcrest-core:$hamcrestVersion" testImplementation "org.hamcrest:hamcrest-library:$hamcrestVersion" testImplementation "org.hamcrest:hamcrest-integration:$hamcrestVersion" androidTestImplementation("androidx.test.espresso:espresso-core:$espresso_core", { exclude group: 'com.android.support', module: 'support-annotations' }) } androidExtensions { experimental = true } apply plugin: 'com.google.gms.google-services' android.packagingOptions { exclude 'LICENSE.txt' exclude 'META-INF/LICENSE.txt' exclude 'META-INF/NOTICE.txt' exclude 'META-INF/rxjava.properties' } configurations.all { resolutionStrategy.force 'com.google.code.findbugs:jsr305:1.3.9' }
I have very similar problem and in my case solution is add in gradle.properties
this two lines:
android.useAndroidX=true android.enableJetifier=true
I hope it will help.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With