Open
Description
Feature Suggestion
Feature Description
I would like to suggest an update for the Android Gradle build configuration within the Firebase Quickstart Flutter project to utilize Gradle's declarative Plugin DSL, moving away from the legacy imperative apply script method. This suggestion aligns with the best practices recommended by Flutter from version 3.16 onwards and aims to enhance build configuration maintainability and facilitate easier future enhancements.
Why Is This Change Important?
- Adherence to Best Practices: According to Flutter's official documentation, the recommended approach for applying Gradle plugins in Flutter projects is now through the declarative Plugin DSL. Adopting this method would ensure the project remains up-to-date with Flutter's best practices.
- Improved Maintainability: By utilizing the Plugin DSL, the project's Gradle plugin management becomes cleaner and more straightforward, improving the overall maintainability of the build configuration.
- Future-Proofing: Preparing the project for potential future updates that could leverage new Gradle features, possibly including the adoption of Kotlin for Gradle scripts.
Proposed Changes
The update would involve modifications to the android/settings.gradle
and android/app/build.gradle
files to define and apply plugins using the declarative syntax. The key adjustments include:
- Implementing the
pluginManagement
andplugins {}
blocks insettings.gradle
for managing plugin versions and applications. - Eliminating the legacy
buildscript
blocks and replacing imperativeapply plugin:
commands with the declarativeplugins {}
block inapp/build.gradle
.
Metadata
Metadata
Assignees
Labels
No labels