![]() https://github.com/flutter/flutter/pull/151675 bumped module templates to AGP 8.1. In doing so, I tried to work around a behavior change [that was new in AGP 8.0](https://developer.android.com/build/releases/past-releases/agp-8-0-0-release-notes): > AGP 8.0 creates no SoftwareComponent by default. Instead AGP creates SoftwareComponents only for variants that are configured to be published using the publishing DSL. by using AGP's publishing DSL to define which variants to publish in the module's ephemeral gradle files: ``` android.buildTypes.all {buildType -> if (!android.productFlavors.isEmpty()) { android.productFlavors.all{productFlavor -> android.publishing.singleVariant(productFlavor.name + buildType.name.capitalize()) { withSourcesJar() withJavadocJar() } } } else { android.publishing.singleVariant(buildType.name) { withSourcesJar() withJavadocJar() } } } ``` The problem is that this doesn't get applied to the plugin projects used by the module, so if a module uses any plugin it breaks. This PR fixes that by applying similar logic, but to each project (not just the module's project). Tested manually with https://github.com/gmackall/GrayAddToApp, and also re-enabled an old test that tested this use case as a part of the PR. Fixes: https://github.com/flutter/flutter/issues/154371 |
||
---|---|---|
.. | ||
android | ||
common | ||
ios | ||
README.md |
Templates for Flutter Module
common
Written to root of Flutter application.
Adds Dart project files including pubspec.yaml
.
android
library
Written to the .android/
hidden folder.
Contents wraps Flutter/Dart code as a Gradle project that defines an Android library.
Executing ./gradlew flutter:assembleDebug
in that folder produces
a .aar
archive.
Android host apps can set up a dependency to this project to consume Flutter views.
gradle
Written to .android/
or android/
.
Mixin for adding Gradle boilerplate to Android projects.
host_app_common
Written to either .android/
or android/
.
Contents define a single-Activity, single-View Android host app
with a dependency on the .android/Flutter
library.
Executing ./gradlew app:assembleDebug
in the target folder produces
an .apk
archive.
Used with either android_host_ephemeral
or android_host_editable
.
host_app_ephemeral
Written to .android/
on top of android_host_common
.
Combined contents define an ephemeral (hidden, auto-generated,
under Flutter tooling control) Android host app with a dependency on the
.android/Flutter
library.
host_app_editable
Written to android/
on top of android_host_common
.
Combined contents define an editable (visible, one-time generated,
under app author control) Android host app with a dependency on the
.android/Flutter
library.
ios
library
Written to the .ios/Flutter
hidden folder.
Contents wraps Flutter/Dart code for consumption by an Xcode project.
iOS host apps can set up a dependency to this contents to consume Flutter views.
host_app_ephemeral
Written to .ios/
outside the Flutter/
sub-folder.
Combined contents define an ephemeral (hidden, auto-generated,
under Flutter tooling control) iOS host app with a dependency on the
.ios/Flutter
folder contents.
The host app does not make use of CocoaPods, and is therefore suitable only when the Flutter part declares no plugin dependencies.
host_app_ephemeral_cocoapods
Written to .ios/
on top of host_app_ephemeral
.
Adds CocoaPods support.
Combined contents define an ephemeral host app suitable for when the Flutter part declares plugin dependencies.