Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fixing: Type XYZ is defined multiple times || packages generated by more than one managed type #764

Closed
moljac opened this issue Jul 19, 2023 · 16 comments

Comments

@moljac
Copy link
Contributor

moljac commented Jul 19, 2023

TL:DR - Fixes

If you are seeing a Java compilation error of the form:

Type androidx.lifecycle.DispatchQueue is defined multiple times: ...
Type kotlin.internal.jdk7.JDK7PlatformImplementations is defined multiple times: ...
Type androidx.collection.ArrayMapKt is defined multiple times: ...

Solution 1

This may be fixable by simply updating your NuGet packages to the latest. This is the preferred solution.

Solution 2

This solution adds an explicit <PackageReference> to the needed transitive package version.

Note: You will need to use versions that match the version of the primary package that is referenced.

If the problematic type starts with androidx.lifecycle, add this to your csproj:

<!-- Should match version of the referenced 'Xamarin.AndroidX.Activity' package -->
<PackageReference Include="Xamarin.AndroidX.Activity.Ktx" Version="1.7.2.1" />

If the problematic type starts with kotlin.internal.jdk7 or kotlin.internal.jdk8, add this to your csproj:

<!-- Should match version of the referenced 'Xamarin.Kotlin.StdLib' package -->
<PackageReference Include="Xamarin.Kotlin.StdLib.Jdk8" Version="1.9.0.1" />

If the problematic type starts with androidx.collection, add this to your csproj:

<!-- Should match version of the referenced 'Xamarin.AndroidX.Collection' package -->
<PackageReference Include="Xamarin.AndroidX.Collection.Jvm" Version="1.4.0.1" />
<PackageReference Include="Xamarin.AndroidX.Collection.Ktx" Version="1.4.0.1" />

How did we get here?

Let's take androidx.lifecycle.DispatchQueue as an example.

The type has always existed in the Java package androidx.lifecycle.lifecycle-runtime-ktx. However, with the 2.6.0 release, Android moved this type to the androidx.lifecycle.lifecycle-common Java package. This is fine if you reference matching versions of the NuGet packages:

  • <PackageReference Include="Xamarin.AndroidX.Lifecycle.Common" Version="2.6.1.3" />
  • <PackageReference Include="Xamarin.AndroidX.Lifecycle.Runtime.Ktx" Version="2.6.1.3" />

However, because these dependencies are referenced by other packages, and NuGet resolves transitive dependencies to the lowest version that satisfies the requirement, you can end up with mismatched references like:

  • <PackageReference Include="Xamarin.AndroidX.Lifecycle.Common" Version="2.6.1.3" />
  • <PackageReference Include="Xamarin.AndroidX.Lifecycle.Runtime.Ktx" Version="2.5.1.1" />

This is not fine, as both packages contain the androidx.lifecycle.DispatchQueue type, resulting in the type being duplicated:

java.exe error JAVA0000: Type androidx.lifecycle.DispatchQueue is defined multiple times: 
  C:\.tools\.nuget\packages\xamarin.androidx.lifecycle.common\2.6.1.3\buildTransitive\net6.0-android31.0\..\..\jar\androidx.lifecycle.lifecycle-common.jar:androidx/lifecycle/DispatchQueue.class, 
  obj\Release\net7.0-android\lp\139\jl\classes.jar:androidx/lifecycle/DispatchQueue.class

Specifically, in MAUI, this occurs because MAUI references Xamarin.AndroidX.Navigation.Common 2.5.2.1, which references Xamarin.AndroidX.Lifecycle.Runtime.Ktx 2.5.1.1:

<PackageReference Include="Xamarin.AndroidX.Navigation.Common" Version="2.5.2.1" />
  -> Xamarin.AndroidX.Lifecycle.Runtime.Ktx (>= 2.5.1.1)  

And the user adds a package like Xamarin.AndroidX.Activity 1.7.2.1 which eventually references Xamarin.AndroidX.Lifecycle.Common 2.6.1.3:

<PackageReference Include="Xamarin.AndroidX.Activity" Version="1.7.2.1" />
  -> Xamarin.AndroidX.Lifecycle.Runtime (>= 2.6.1.3)
     -> Xamarin.AndroidX.Lifecycle.Common (>= 2.6.1.3)

How does Java/Maven handle this?

Java/Maven avoids this issue by requiring an exact version match between androidx.lifecycle.lifecycle-runtime-ktx and androidx.lifecycle.lifecycle-common. That is, the POM file for androidx.lifecycle.lifecycle-runtime-ktx lists its dependency as:

<!-- lifecycle-runtime-ktx-2.6.1.pom -->
<dependency>
  <groupId>androidx.lifecycle</groupId>
  <artifactId>lifecycle-runtime</artifactId>
  <version>[2.6.1]</version>
  <scope>compile</scope>
  <type>aar</type>
</dependency>

The square brackets ([]) denote an exact match, rather than a greater than or equal match.

Our NuGet packages allow greater than or equal match, which allows the version to incorrectly differ from each other.

Long-term fix

In order to handle this long-term and help prevent this issue from recurring when other types move in the future, we need to duplicate Java/Maven's "exact match".

Unfortunately, publishing fixed packages will not make this error go away yet, because the fixed package needs to be referenced by MAUI. After fixed packages are published, MAUI will need to reference them and make a new release.

Thus, we will be living with the issue for a while.

Caveats

Using "exact match" versions will fix the androidx.lifecycle case (and potential future cases), but it will not fix the kotlin.internal case, as the Kotlin POM does not specify an "exact match" for this case:

<!-- kotlin-stdlib-jdk8-1.9.0.pom -->
<dependency>
  <groupId>org.jetbrains.kotlin</groupId>
  <artifactId>kotlin-stdlib</artifactId>
  <version>1.9.0</version>
  <scope>compile</scope>
</dependency>

Original Details

Certain PackageReference constellations can cause 2 errors:

  • type XYZ is defined multiples times
    or
  • packages generated by more than one managed type

Basically, the problem is that maven package authors (Google, JetBrains) move types from version to version, from Maven artifact to another Maven artifact. So, in rare cases even trivial transitive dependencies cause such errors if nugets transitively reference nugets with bindings where the same type rasides, but under different version.

Team does publish "alingment bumps" to put transitive dependencies "in order", but probability for hitting these issues is still high on real world projects, especially with 3rd party libraries that depend on older AndroidX and GooglePlayServices-Firebase-MLKit (not regularly updated).

Workaround steps:

  1. update AndroidX and GooglePlayServices-Firebase-MLKit to the latest
    sometimes updating AndroidX 1st could help, but recommendation is to update all PackageReferences
  2. some users report that they had to close Visual Studio (IDE) and delete bin/ and obj folders, restore and then build

If you still encounter these issues open issue in AndroidX and/or GooglePlayServices-Firebase-MLKit repos and please add list of PackageRererences.

Related/Duplicates:

This issue is project specific (PackagesReferences dependent), so finding workaround is based on experience.

Finding newer issues - search for;

Error JAVA0000 java.exe: Error in Type androidx.collection.ArrayMapKt is defined multiple times

Thus list of the similar issues:

AX (AndroidX)

#1068

#938

#935

#926

#918

#861

#805

#800

#797

#793

#788

#752

#749

#747

#742

#717

#634

#525

#509

#505

#756 (comment)

GPS-FB-MLKit (GooglePlayServices, Firebase, ML Kit)

xamarin/GooglePlayServicesComponents#909

xamarin/GooglePlayServicesComponents#898

xamarin/GooglePlayServicesComponents#897

xamarin/GooglePlayServicesComponents#889

xamarin/GooglePlayServicesComponents#852

xamarin/GooglePlayServicesComponents#825

xamarin/GooglePlayServicesComponents#475

xamarin/GooglePlayServicesComponents#379

MAUI

dotnet/maui#27079

dotnet/maui#26963

dotnet/maui#25261

dotnet/maui#20561

dotnet/maui#18665

dotnet/maui#18118

dotnet/maui#17935

dotnet/maui#16448

dotnet/maui#14954

dotnet/maui#11353 (comment)

Diverse (Plugins)

marcojak/MauiMTAdmob#113

More references

https://stackoverflow.com/questions/77487528/net-maui-push-notifications-with-firebase-cloud-mesaging

firebase/firebase-android-sdk#5997

firebase/firebase-android-sdk#5999

https://stackoverflow.com/questions/66344110/r8-says-type-is-defined-multiple-times-in-build-transforms-and-in-build-tmp-ko/

Steps to Reproduce

N/A

Did you find any workaround?

Workaround steps:

  1. update AndroidX and GooglePlayServices-Firebase-MLKit to the latest
    sometimes updating AndroidX 1st could help, but recommendation is to update all PackageReferences
  2. some users report that they had to close Visual Studio (IDE) and delete bin/ and obj folders, restore and then build

Relevant log output

see related issues
@moljac moljac pinned this issue Jul 19, 2023
@moljac moljac changed the title Error: Type XYZ is defined multiples times || packages generated by more than one managed type Error: Type XYZ is defined multiple times || packages generated by more than one managed type Jul 19, 2023
@jpobst jpobst changed the title Error: Type XYZ is defined multiple times || packages generated by more than one managed type Fixing: Type XYZ is defined multiple times || packages generated by more than one managed type Jul 27, 2023
@fedemkr
Copy link

fedemkr commented Jul 28, 2023

We have a Xamarin.Forms app and given that we're having several issues upgrading to MAUI we decided to give a try upgrading the platforms (Android & iOS) to .NET 7 and check how it goes. However, I'm having this issue on the Android project on .NET 7 and tried all the proposed solutions/workarounds but still getting the error on MediaSessionCompat:

/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215: The Java type `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` is generated by more than one managed type. Please change the [Register] attribute so that the same Java type is not emitted. [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]
/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215:   `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` generated by: Android.Support.V4.Media.Session.MediaSessionCompat+IOnActiveChangeListenerImplementor, Xamarin.Android.Support.Media.Compat, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]
/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215:   `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` generated by: Android.Support.V4.Media.Session.MediaSessionCompat+IOnActiveChangeListenerImplementor, Xamarin.AndroidX.Media, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]

Installed packages:

<PackageReference Include="Plugin.CurrentActivity" Version="2.1.0.4" />
<PackageReference Include="Portable.BouncyCastle" Version="1.9.0" />
<PackageReference Include="Xamarin.AndroidX.AutoFill" Version="1.1.0.18" />
<PackageReference Include="Xamarin.AndroidX.Core" Version="1.10.1.2" />
<PackageReference Include="Xamarin.AndroidX.AppCompat" Version="1.6.1.3" />

Is there anything else we could try?

Edit: Tried also on .Net 8 preview 6 and getting the same issue. And tried the previous version of the AndroidX libraries ending on the same result.

@moljac
Copy link
Contributor Author

moljac commented Jul 28, 2023

@fedemkr I will create minimal repro sample on Sunday.

Looking good:

https://www.nuget.org/packages/Xamarin.AndroidX.AutoFill/1.1.0.18
https://www.nuget.org/packages/Xamarin.AndroidX.Core/1.10.1.2
https://www.nuget.org/packages/Xamarin.AndroidX.AppCompat/1.6.1.3

Cannot repro with net8.0. I will try net7.0 next week

@jpobst
Copy link
Contributor

jpobst commented Jul 28, 2023

@fedemkr It looks like you are using both Android Support Libraries and AndroidX:

  • Xamarin.Android.Support.Media.Compat
  • Xamarin.AndroidX.Media

It is highly recommended to migrate away from Android Support Libraries, as Google deprecated and stopped developing them many years ago.

In .NET 6+, we no longer run the Android Support -> AndroidX migration automatically for you. To make it run, add a reference to the Xamarin.AndroidX.Migration NuGet package. This will hopefully fix the duplication.

@moljac
Copy link
Contributor Author

moljac commented Jul 29, 2023

Looks like it was really late and I missed details in this error:

/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215: The Java type `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` is generated by more than one managed type. Please change the [Register] attribute so that the same Java type is not emitted. [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]
/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215:   `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` generated by: Android.Support.V4.Media.Session.MediaSessionCompat+IOnActiveChangeListenerImplementor, Xamarin.Android.Support.Media.Compat, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]
/usr/local/share/dotnet/packs/Microsoft.Android.Sdk.Darwin/33.0.68/tools/Xamarin.Android.Common.targets(1476,3): error XA4215:   `mono.android.support.v4.media.session.MediaSessionCompat_OnActiveChangeListenerImplementor` generated by: Android.Support.V4.Media.Session.MediaSessionCompat+IOnActiveChangeListenerImplementor, Xamarin.AndroidX.Media, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null [/Users/user/Projects/MyProject/Mobile/src/Android/Android.csproj::TargetFramework=net7.0-android]

I will use stronger words - one MUST get rid of Android.Support - for own sanity. It is old and unsupported and probably tons of security and other issues.

@jamesmontemagno
Copy link
Member

jamesmontemagno commented Aug 4, 2023

Don't use:

<PackageReference Include="Plugin.CurrentActivity" Version="2.1.0.4" />

It is built into .NET MAUI: https://learn.microsoft.com/en-us/dotnet/maui/platform-integration/platform-helpers?tabs=android

@moljac
Copy link
Contributor Author

moljac commented Aug 5, 2023

It is built into .NET MAUI: https://learn.microsoft.com/en-us/dotnet/maui/platform-integration/platform-helpers?tabs=android

Didn't know that. I just checked date of the latest release and it is 2018-05. I didn't dive into dependencies and it does not have any, so it should be OK, because it does not pull in transitive dependencies.

I think in this case the problem is with mixing Android.Support and AndroidX as jpobst stated. But to be sure I would need to dive in deeper into dependency graph/tree/forest.

ThreeSevenths added a commit to santedb/santedb-dc-android that referenced this issue Oct 5, 2023
@jpobst jpobst removed the packages label Mar 14, 2024
@marcelo-g-simas
Copy link

marcelo-g-simas commented Jul 16, 2024

This is happening after updating Plugin.LocalNotification to the latest 11.1.4.

MSBUILD : java error JAVA0000: Error in /.nuget/packages/xamarin.androidx.collection.jvm/1.4.0.4/buildTransitive/net8.0-android34.0/../../jar/androidx.collection.collection-jvm.jar:androidx/collection/ArrayMapKt.class: 

MSBUILD : java error JAVA0000: Type androidx.collection.ArrayMapKt is defined multiple times: /.nuget/packages/xamarin.androidx.collection.jvm/1.4.0.4/buildTransitive/net8.0-android34.0/../../jar/androidx.collection.collection-jvm.jar:androidx/collection/ArrayMapKt.class, 

/.nuget/packages/xamarin.androidx.collection.ktx/1.2.0.9/buildTransitive/net6.0-android31.0/../../jar/androidx.collection.collection-ktx.jar:androidx/collection/ArrayMapKt.class 

.NET MAUI building on MacOS with latest MAUI workloads and using the latest packages.

dotnet --version
8.0.303

@jeff-eats-pubsubs
Copy link

jeff-eats-pubsubs commented Jul 23, 2024

In this case: updating to the newest versions is causing errors.

This works great!

<ItemGroup Condition="'$(TargetFramework)' == 'net8.0-android'">
	<PackageReference Include="Xamarin.AndroidX.Activity.Ktx" Version="1.7.2.1" />
	<PackageReference Include="Xamarin.Firebase.Messaging" Version="123.1.1.1"/>
	<PackageReference Include="Xamarin.Google.Dagger" Version="2.44.2.1"/>
	<PackageReference Include="Xamarin.GooglePlayServices.Base" Version="118.1.0.1"/>
</ItemGroup>

This fails to build.

<ItemGroup Condition="'$(TargetFramework)' == 'net8.0-android'">
	<PackageReference Include="Xamarin.AndroidX.Activity.Ktx" Version="1.9.0.4" />
	<PackageReference Include="Xamarin.Firebase.Messaging" Version="124.0.0" />
	<PackageReference Include="Xamarin.Google.Dagger" Version="2.51.1" />
	<PackageReference Include="Xamarin.GooglePlayServices.Base" Version="118.5.0" />
</ItemGroup>

with

1>MSBUILD : java.exe error JAVA0000: Error in obj\Release\net8.0-android\lp\145\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class:
1>MSBUILD : java.exe error JAVA0000: Type androidx.lifecycle.LiveDataKt$observe$wrappedObserver$1 is defined multiple times: obj\Release\net8.0-android\lp\145\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class, obj\Release\net8.0-android\lp\185\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class
1>MSBUILD : java.exe error JAVA0000: Compilation failed
1>MSBUILD : java.exe error JAVA0000: java.lang.RuntimeException: com.android.tools.r8.CompilationFailedException: Compilation failed to complete, origin: obj\Release\net8.0-android\lp\145\jl\classes.jar
1>MSBUILD : java.exe error JAVA0000: androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:135)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.main(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:5)
1>MSBUILD : java.exe error JAVA0000: Caused by: com.android.tools.r8.CompilationFailedException: Compilation failed to complete, origin: obj\Release\net8.0-android\lp\145\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class
1>MSBUILD : java.exe error JAVA0000: 	at Version.fakeStackEntry(Version_8.2.33.java:0)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.T.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:5)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:82)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:32)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:31)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.b(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:2)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:42)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.b(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:13)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:40)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:122)
1>MSBUILD : java.exe error JAVA0000: 	... 1 more
1>MSBUILD : java.exe error JAVA0000: Caused by: com.android.tools.r8.utils.b: Type androidx.lifecycle.LiveDataKt$observe$wrappedObserver$1 is defined multiple times: obj\Release\net8.0-android\lp\145\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class, obj\Release\net8.0-android\lp\185\jl\classes.jar:androidx/lifecycle/LiveDataKt$observe$wrappedObserver$1.class
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.Q2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:21)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:54)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:10)
1>MSBUILD : java.exe error JAVA0000: 	at java.base/java.util.concurrent.ConcurrentHashMap.merge(ConcurrentHashMap.java:2056)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:6)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.graph.m4$a.d(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:6)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:61)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:12)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:9)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:45)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.d(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:17)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.c(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:69)
1>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:28)
1>MSBUILD : java.exe error JAVA0000: 	... 6 more
1>MSBUILD : java.exe error JAVA0000: Directory 'obj\Release\net8.0-android\lp\145' is from 'androidx.lifecycle.lifecycle-livedata-core.aar'.

@PavloLukianets
Copy link

PavloLukianets commented Jul 30, 2024

@jpobst @moljac
Just adding

<PackageReference Include="Xamarin.Firebase.Perf" Version="121.0.1.1" />

to a blank net8.0 android app also produces similar error:

0>: Error JAVA0000 java: Error in obj/Debug/net8.0-android/lp/173/jl/classes.jar:com/google/protobuf/DescriptorProtos$1.class:
Type com.google.protobuf.DescriptorProtos$1 is defined multiple times: obj/Debug/net8.0-android/lp/173/jl/classes.jar:com/google/protobuf/DescriptorProtos$1.class, obj/Debug/net8.0-android/lp/162/jl/libs/8E428AF64A795598.jar:com/google/protobuf/DescriptorProtos$1.class
...
Directory 'obj/Debug/net8.0-android/lp/151' is from 'protolite-well-known-types.aar'.

By adding the line below the error is gone, however i doubt if it's a correct workaround

<PackageReference Include="Xamarin.Firebase.ProtoliteWellKnownTypes" Version="118.0.0.17" ExcludeAssets="All" />

After adding this i get runtime error: Field transportInfo_ for com.google.firebase.perf.v1.PerfMetric not found

@FGVN
Copy link

FGVN commented Aug 20, 2024

Solution 1 did not work for me, also got stuck at live error, but using @jeff-eats-pubsubs solution with using older version of firebase seems to have helped and the project is built successfully

@mikeluken
Copy link

I also do not have a solution that works yet unless I use an older version....

<ItemGroup Condition="'$(TargetFramework)' == 'net8.0-android'">
  <GoogleServicesJson Include="google-services.json" />
  <PackageReference Include="Xamarin.AndroidX.Core" Version="1.13.1.3" />
  <PackageReference Include="Xamarin.AndroidX.Collection" Version="1.4.2" />
  <PackageReference Include="Xamarin.AndroidX.Collection.Ktx" Version="1.4.2" />
  <PackageReference Include="Xamarin.AndroidX.Activity.Ktx" Version="1.9.1" />
 <PackageReference Include="Xamarin.Google.Android.Material" Version="1.11.0.1" />
</ItemGroup>

Produces the following error:

4>MSBUILD : java.exe error JAVA0000: Error in obj\Debug\net8.0-android\lp\198\jl\classes.jar:androidx/lifecycle/LiveDataKt.class:
4>MSBUILD : java.exe error JAVA0000: Type androidx.lifecycle.LiveDataKt is defined multiple times: obj\Debug\net8.0-android\lp\198\jl\classes.jar:androidx/lifecycle/LiveDataKt.class, obj\Debug\net8.0-android\lp\240\jl\classes.jar:androidx/lifecycle/LiveDataKt.class
4>MSBUILD : java.exe error JAVA0000: Compilation failed
4>MSBUILD : java.exe error JAVA0000: java.lang.RuntimeException: com.android.tools.r8.CompilationFailedException: Compilation failed to complete, origin: obj\Debug\net8.0-android\lp\198\jl\classes.jar
4>MSBUILD : java.exe error JAVA0000: androidx/lifecycle/LiveDataKt.class
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:135)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.main(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:5)
4>MSBUILD : java.exe error JAVA0000: Caused by: com.android.tools.r8.CompilationFailedException: Compilation failed to complete, origin: obj\Debug\net8.0-android\lp\198\jl\classes.jar:androidx/lifecycle/LiveDataKt.class
4>MSBUILD : java.exe error JAVA0000: 	at Version.fakeStackEntry(Version_8.2.33.java:0)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.T.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:5)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:82)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:32)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:31)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.b(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:2)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:42)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.b(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:13)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:40)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:122)
4>MSBUILD : java.exe error JAVA0000: 	... 1 more
4>MSBUILD : java.exe error JAVA0000: Caused by: com.android.tools.r8.utils.b: Type androidx.lifecycle.LiveDataKt is defined multiple times: obj\Debug\net8.0-android\lp\198\jl\classes.jar:androidx/lifecycle/LiveDataKt.class, obj\Debug\net8.0-android\lp\240\jl\classes.jar:androidx/lifecycle/LiveDataKt.class
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.Q2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:21)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:54)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:10)
4>MSBUILD : java.exe error JAVA0000: 	at java.base/java.util.concurrent.ConcurrentHashMap.merge(ConcurrentHashMap.java:2056)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.D2.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:6)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.graph.m4$a.d(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:6)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:61)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:12)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.dex.c.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:9)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:45)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.d(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:17)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.D8.c(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:69)
4>MSBUILD : java.exe error JAVA0000: 	at com.android.tools.r8.utils.S0.a(R8_8.2.33_429c93fd24a535127db6f4e2628eb18f2f978e02f99f55740728d6b22bef16dd:28)
4>MSBUILD : java.exe error JAVA0000: 	... 6 more
4>MSBUILD : java.exe error JAVA0000: Directory 'obj\Debug\net8.0-android\lp\198' is from 'androidx.lifecycle.lifecycle-livedata-core.aar'.

@tranb3r
Copy link

tranb3r commented Aug 29, 2024

@jpobst @moljac Just adding

<PackageReference Include="Xamarin.Firebase.Perf" Version="121.0.1.1" />

to a blank net8.0 android app also produces similar error:

0>: Error JAVA0000 java: Error in obj/Debug/net8.0-android/lp/173/jl/classes.jar:com/google/protobuf/DescriptorProtos$1.class:
Type com.google.protobuf.DescriptorProtos$1 is defined multiple times: obj/Debug/net8.0-android/lp/173/jl/classes.jar:com/google/protobuf/DescriptorProtos$1.class, obj/Debug/net8.0-android/lp/162/jl/libs/8E428AF64A795598.jar:com/google/protobuf/DescriptorProtos$1.class
...
Directory 'obj/Debug/net8.0-android/lp/151' is from 'protolite-well-known-types.aar'.

By adding the line below the error is gone, however i doubt if it's a correct workaround

<PackageReference Include="Xamarin.Firebase.ProtoliteWellKnownTypes" Version="118.0.0.17" ExcludeAssets="All" />

After adding this i get runtime error: Field transportInfo_ for com.google.firebase.perf.v1.PerfMetric not found

Is there a fix for this issue ?

@PavloLukianets
Copy link

@tranb3r not yet, follow xamarin/GooglePlayServicesComponents#898

ThreeSevenths added a commit to santedb/santedb-dc-android that referenced this issue Sep 13, 2024
…t/android-libraries#764 for more info. Added initial configuration types to support configuration system.
jpobst added a commit that referenced this issue Sep 13, 2024
"Pause" migrating everything to a common template, and pivot to moving the remaining packages from the GPS repository to the AndroidX repository.  This should enable us to eliminate the circular dependencies between the two repositories which should help fix the majority of the #764 issues going forward.

Bring in the GPS and Glide templates as new "templateSet", and merge in all the build infrastructure pieces that the GPS repository had to make it build correctly.
@Sajjad-Alizadeh
Copy link

Read this solution:
https://stackoverflow.com/a/79121053

@OvrBtn
Copy link

OvrBtn commented Dec 29, 2024

A little tip for future generations also having this issue.

In my case nothing I could find online was helping so here is a generic aproach I took which actually helped me and which could be useful in the future:

  1. Build the project
  2. Look for "Type androidx.lifecycle.LiveDataKt is defined multiple times:" or similar message, here we see that LiveDataKt (which was defined multiple times) is from androidx.lifecycle namespace
  3. Open command line and navigate to your project
  4. Run dotnet list package --include-transitive in command line
  5. [optional] Command line might cut some of the output since the buffer might be too small, if you don't see whole output: right click at cmd window -> layout and then in buffer size set height to something bigger
  6. Locate packages for android, it probably will be at the top below blue "[net8.0-android]:" or similar (dependeds on version of your project)
  7. Under transimitive packages look for packages with the same namespace as you found in step 2.
  8. Some packages you located in step 7. will have different versions for example
> Xamarin.AndroidX.Activity                        1.9.3.1
> Xamarin.AndroidX.Activity.Ktx                                 1.7.2.1

In this case Xamarin.AndroidX.Activity.Ktx has lower version that Xamarin.AndroidX.Activity
9. Go to Nuget manager in whatever IDE you use (or just use CLI) and update package which had lower version (from step 8.) to the same version as the other package which had higher version.
10. Go to step 1. and repeat until your project builds

@moljac
Copy link
Contributor Author

moljac commented Dec 29, 2024

A little tip for future generations also having this issue.

In my case nothing I could find online was helping so here is a generic aproach I took which actually helped me and which could be useful in the future:

  1. Build the project
  2. Look for "Type androidx.lifecycle.LiveDataKt is defined multiple times:" or similar message, here we see that LiveDataKt (which was defined multiple times) is from androidx.lifecycle namespace
  3. Open command line and navigate to your project
  4. Run dotnet list package --include-transitive in command line
  5. [optional] Command line might cut some of the output since the buffer might be too small, if you don't see whole output: right click at cmd window -> layout and then in buffer size set height to something bigger
  6. Locate packages for android, it probably will be at the top below blue "[net8.0-android]:" or similar (dependeds on version of your project)
  7. Under transimitive packages look for packages with the same namespace as you found in step 2.
  8. Some packages you located in step 7. will have different versions for example
> Xamarin.AndroidX.Activity                        1.9.3.1
> Xamarin.AndroidX.Activity.Ktx                                 1.7.2.1

In this case Xamarin.AndroidX.Activity.Ktx has lower version that Xamarin.AndroidX.Activity 9. Go to Nuget manager in whatever IDE you use (or just use CLI) and install package which had lower version (from step 8.) 10. Go to step 1. and repeat until your project builds

Thanks for the feedback

Another tip/trick you can use --framework <FRAMEWORK> option to filter out non Android packages.

https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet-list-package#options

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests