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.