除了 buildSrc 还能这样统一配置依赖版本?巧用 includeBuild

buildSrc 的缺陷

Android 开发中统一不同 module 的依赖版本十分重要,传统的方式是使用 ext 的方式

ext

之前我发过关于使用 buildSrc 简化项目中 gradle 代码的译文:什么?项目里gradle代码超过200行了!你可能需要 Kotlin+buildSrc Plugin

该种方式可以很好的管理 gradle 的公共配置,这其中当然包括依赖版本

配置依赖

如图,在使用依赖时有代码提示,而且可以点击进入查看

但是由于 buildSrc 是对全局的所有 module 的配置,因此在构建速度上会慢一些。那么有没有一个更纯净的方式来配置依赖版本呢?

今天我们来介绍一种新的方式

自定义 plugin + includeBuild

使用 Gradle Composite builds 可以很容易解决这一问题

我们新建一个 module,命名为 version ,并将原来的 buildSrc 的代码转移过来

1
2
3
4
5
class DependencyVersionPlugin : Plugin<Project> {
override fun apply(project: Project) {

}
}

在 version 的 build.gradle 文件加入

1
2
3
4
5
6
7
8
gradlePlugin {
plugins {
version {
id = 'com.flywith24.version'
implementationClass = 'com.flywith24.version.DependencyVersionPlugin'
}
}
}

在 settings.gradle 加入 includeBuild("version")重点

1
2
3
4
5
includeBuild("version")

rootProject.name='VersionControlDemo'
include ':app'
include ':lib'

接下来在需要引用的 module 中引入该插件

1
2
3
plugins {
id "com.flywith24.version"
}

之后我们就可以使用了

Demo

demo代码截图

demo代码截图

demo 在这

往期文章

该系列主要介绍一些「骚操作」,它未必适合生产环境使用,但是是一些比较新颖的思路

我的其他系列文章 在这里

关于我

我是 Flywith24,我的博客内容已经分类整理 在这里,点击右上角的 Watch 可以及时获取我的文章更新哦 😉

查看评论