android {
compileSdkVersion rootProject.ext.android.compileSdkVersion
buildToolsVersion rootProject.ext.android.buildToolsVersion
defaultConfig {
applicationId “com.androidwind.androidquick”
minSdkVersion rootProject.ext.android.minSdkVersion
targetSdkVersion rootProject.ext.android.targetSdkVersion
versionCode rootProject.ext.android.versionCode
versionName rootProject.ext.android.versionName
}
}
这样配置的好处就是可以不用将配置信息全部写在项目的build.gradle文件内,通过单独的gradle文件保存,达到分类清晰便于管理的目的。
使用.each引入依赖库
======================================================================
以上面的config.gradle文件为例,dependencies是我们设定的依赖库集合,那我们在app模块下面如果想引用这些依赖库怎么办?
普通的做法就是通过声明依赖一个一个地引进来:
implementation rootProject.ext.dependencies[“appcompatv7”]
我们可以通过groovy的.each方法批量加入引用,以app模块的build.gradle为例:
dependencies {
app.each {
implementation it
}
}
任务信息
==============================================================
除了可以存放配置信息外,gradle文件当然还可以执行脚本任务。
groovy中的任务是以task开头的,比如项目的build.gradle里面有一个删除的任务:
task clean(type: Delete) {
delete rootProject.buildDir
}
接下来我们以一个实例来了解下任务是怎么使用的。
我们以checkStyle代码检测规范为例,我们制定了一系列的代码检测规范,希望提交上去的代码都是符合代码规范的,那么我们能希望在源头,也就是build项目的时候就能够同时进行代码规范检测,这样能够保证我们不会提交不符合代码规范的代码到服务器上。
同样我们新建一个checkstyle.gradle文件,顾名思义,里面就是存放代码规范检测相关的逻辑的。
allprojects {
project ->
// 代码规范检查
apply plugin: ‘checkstyle’
checkstyle {
configFile rootProject.file(‘config/quality/checkstyle/checkstyle.xml’)
toolVersion ‘8.2’
ignoreFailures false
showViolations true
}
task(‘checkstyle’, type: Checkstyle) {
source ‘src/main/java’
include ‘**/*.java’
exclude ‘/gen/’
classpath = files()
}
tasks.whenTaskAdded { task ->
boolean runCheckStyleOnLocalDev = “${enable_checkstyle}”.toBoolean()
boolean runCheckStyleTask = task.name == ‘prepareReleaseDependencies’ || (runCheckStyleOnLocalDev && task.name == ‘preBuild’)
if (runCheckStyleTask) { //prepareReleaseDependencies, preBuild
println(“checkstyle run task.name :” + task.name)
task.dependsOn ‘checkstyle’
}
}
}
然后在项目的build.gradle中引入:
apply from: ‘checkstyle.gradle’
或者
apply from: ‘./checkstyle.gradle’