The build-logic
folder defines project-specific convention plugins, used to keep a single
source of truth for common module configurations.
This approach is heavily based on https://developer.squareup.com/blog/herding-elephants/ and https://github.com/jjohannes/idiomatic-gradle.
By setting up convention plugins in build-logic
, we can avoid duplicated build script setup,
messy subproject
configurations, without the pitfalls of the buildSrc
directory.
build-logic
is an included build, as configured in the root
settings.gradle.kts
.
Inside build-logic
is a convention
module, which defines a set of plugins that all normal
modules can use to configure themselves.
build-logic
also includes a set of Kotlin
files used to share logic between plugins themselves,
which is most useful for configuring Android components (libraries vs applications) with shared
code.
These plugins are additive and composable, and try to only accomplish a single responsibility.
Modules can then pick and choose the configurations they need.
If there is one-off logic for a module without shared code, it's preferable to define that directly
in the module's build.gradle
, as opposed to creating a convention plugin with module-specific
setup.
- Navigate to Your Project's Root Directory
- Add the Repository as a Submodule:
git submodule add git@github.com:raxden/android-convention.git
- Change the name of the folder to build-logic
git mv android-convention build-logic
- Modify your
settings.gradle.kts
setting the path of toml.
pluginManagement {
includeBuild("build-logic")
...
}
...
dependencyResolutionManagement {
versionCatalogs {
create("libs") { from(files("build-logic/gradle/libraries.versions.toml")) }
}
...
}
Kotlin
plugins {
id("com.raxdenstudios.android-application")
}
Groovy
plugins {
id 'com.raxdenstudios.android-application'
}
Kotlin
plugins {
id("android-library-conventions")
}
Groovy
plugins {
id 'com.raxdenstudios.android-library'
}
Kotlin
plugins {
id("com.raxdenstudios.android-feature")
}
Groovy
plugins {
id 'com.raxdenstudios.android-feature'
}
Kotlin
plugins {
id("com.raxdenstudios.android-compose-application")
}
Groovy
plugins {
id 'com.raxdenstudios.android-compose-application'
}
Kotlin
plugins {
id("com.raxdenstudios.android-compose-library")
}
Groovy
plugins {
id 'com.raxdenstudios.android-compose-library'
}
Kotlin
plugins {
id("com.raxdenstudios.android-compose-feature")
}
Groovy
plugins {
id 'com.raxdenstudios.android-compose-feature'
}