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 and plugins {} blocks in settings.gradle for managing plugin versions and applications.
- Eliminating the legacy
buildscript blocks and replacing imperative apply plugin: commands with the declarative plugins {} block in app/build.gradle.
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?
Proposed Changes
The update would involve modifications to the
android/settings.gradleandandroid/app/build.gradlefiles to define and apply plugins using the declarative syntax. The key adjustments include:pluginManagementandplugins {}blocks insettings.gradlefor managing plugin versions and applications.buildscriptblocks and replacing imperativeapply plugin:commands with the declarativeplugins {}block inapp/build.gradle.