You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I couldn't add comment to the already closed issue #5354 thus opened new one.
Original description
Environment
Android Studio version: Iguana 2023.2.1
Firebase Component: Crashlytics Gradle Plugin
Component version: 2.9.9 (But started in 2.9.5)
The problem
Cyclic dependency between gradle tasks after trying to upgrade Crashlytics Gradle Plugin to 2.9.9.
In our setup we first build java/kotlin code, obfuscate it using R8, then use the R8 outputs to obfuscate JNI headers. This makes the buildCMake task depend on building java/kotlin code and R8.
After updating to 2.9.9 the injectCrashlyticsBuildIdsRelease task kicks in which seems to be necessary to mergeReleaseResources but at the same time depends on outputs from the native build which is the opposite order we have in our code. This causes cyclic dependency between gradle tasks. See output from the console:
In the mentioned issue #5354 there was a suggestion to generate the R8 mapping upfront and provide that mapping to R8 using the -applymapping rule.
We started investigating this option. We used KSP to generate the preliminary mapping file. However we faced an issue where JNI headers are generated by the java compiler (javac -h). This still establish the task order where native code can only be compiled after javac/kotlinc.
We are currently investigating if we could utilize the KSP to generate the JNI headers as well. However I think you should really consider the idea of keeping the build ids in assets rather than as resources.
The text was updated successfully, but these errors were encountered:
I considered doing this before. The thing that stopped me is we didn't want to create a dependency requirement between versions of the Gradle plugin and versions of the SDK.
So instead, I can do this in the plugin behind a flag, and then require a gradle property and the latest SDK for it to work.
I think having extra flag for that is perfectly fine for us. We are also evaluating if we can get rid of javac to generate jni headers.
Side question: We still use old version of the Gradle plugin, but we keep updating Crashlytics. Is there actually any benefit having latest plugin?
We mark this as a feature request. While we are unable to promise any timeline for this, we'll definitely keep this under our radar.
P.S. For folks who find this useful, adding an emoji thumbs up on the original post can help us prioritize adding this to the roadmap.
As for your side question:Firebase Crashlytics Gradle plugin streamlines integrating Crashlytics into your Android project. It:
Manages library dependencies: Automatically includes necessary Crashlytics libraries.
Generates symbol files: Creates symbol files that map obfuscated crash reports back to your original source code for easier debugging.
Customizes Crashlytics behavior: Enables or disables features to tailor Crashlytics to your needs.
Facilitates backend communication: Manages communication between your app and Firebase Crashlytics.
For optimal performance and stability, always use the latest Firebase SDK/plugin. This ensures you benefit from the most recent updates, bug fixes, and improvements.
I couldn't add comment to the already closed issue #5354 thus opened new one.
Original description
Environment
Android Studio version: Iguana 2023.2.1
Firebase Component: Crashlytics Gradle Plugin
Component version: 2.9.9 (But started in 2.9.5)
The problem
Cyclic dependency between gradle tasks after trying to upgrade Crashlytics Gradle Plugin to 2.9.9.
In our setup we first build java/kotlin code, obfuscate it using R8, then use the R8 outputs to obfuscate JNI headers. This makes the buildCMake task depend on building java/kotlin code and R8.
After updating to 2.9.9 the injectCrashlyticsBuildIdsRelease task kicks in which seems to be necessary to mergeReleaseResources but at the same time depends on outputs from the native build which is the opposite order we have in our code. This causes cyclic dependency between gradle tasks. See output from the console:
In the mentioned issue #5354 there was a suggestion to generate the R8 mapping upfront and provide that mapping to R8 using the
-applymapping
rule.We started investigating this option. We used KSP to generate the preliminary mapping file. However we faced an issue where JNI headers are generated by the java compiler (
javac -h
). This still establish the task order where native code can only be compiled afterjavac/kotlinc
.We are currently investigating if we could utilize the KSP to generate the JNI headers as well. However I think you should really consider the idea of keeping the build ids in assets rather than as resources.
The text was updated successfully, but these errors were encountered: