Gradle任务
多种方式创建任务
1、直接以一个任务名字创建一个任务的方式:
def Task task1 = task(task1)
task1.doLast{
println 'task1'
}
这种方式的创建其实是调用Project对象中的task(String name)方法。该方法的完整定义:
Task task(String name) throws InvalidUserDataException
2、以一个任务名字+一个对该任务配置的Map对象来创建任务:
def Task task2 = task(task2,group:BasePlugin.BUILD_GROUP)
task2.doLast{
println 'task2'
}
Task参数Map可用配置
type | 基于一个存在的Task来创建,和我们类继承差不多 | DefaultTask |
overwrite | 是否替换存在的Task,这个和type配合起来用 | false |
dependsOn | 用于配置任务的依赖 | [] |
action | 添加到任务中的一个Action或者闭包 | null |
description | 用于配置任务的描述 | null |
group | 用于配置任务的分组 | null |
3、任务名字+闭包配置的方式:
task task3{
description 'task3'
doLast{
println 'task3'
println "任务描述:${description}"
}
}
Map配置的项有限,所以可以通过闭包的方式进行更加灵活的配置。闭包里的委托对象就是Task,所以你可以使用Task对象的任何方法,属性等信息。
TaskContainer创建任务的方式:
tasks.create("task4"){
description 'task4'
doLast{
println 'task4'
println "任务描述:${description}"
}
}
tasks是Project对象的属性,其类型是TaskContainer,可以用它来直接创建任务。
多种方式访问任务
创建的任务都会作为项目的一个属性,属性名就是任务名,所以可以直接通过任务名称来访问和操作任务:
task task5
task5.doLast{
println 'task5:doLast'
}
任务都是通过TaskContainer创建的,其实TaskContainer就是我们创建的集合。在Project中可以通过tasks属性访问TaskContainer,所以可以通过访问集合的方式来访问创建的任务:
task task6
tasks['task6'].doLast{
println 'task6:doLast'
}
通过路径来访问。访问方式有两种,一种是get,一种是find,区别在于get如果找不到任务会抛出UnKnownTaskException异常,而find在找不到任务时返回null。
task task7
tasks['task7'].doLast{
println tasks.findByPath(':Chapter4:task7')
println tasks.getByPath(':Chapter4:task7')
println tasks.findByPath('abc')
}
通过名称访问。方式也有两种:get和find,区别和路径方式相同:
task task8
tasks['task8'].doLast{
println tasks.findByName('task8')
println tasks.findByName('task8')
println tasks.findByName('abc')
}
通过路径访问的时候,参数值可以是任务路径,也可以是任务名字。而通过名称访问,参数只能是任务名称,不能是路径。
任务分组和描述
任务是可以分组和添加描述的。任务分组其实就是对任务分类,便于对任务归类整理。任务的描述就是说明任务有什么用,是任务的大概说明。
task task9{
group BasePlugin.BUILD_GROUP
description '构建任务'
doLast{
println 'task9:doLast'
}
}
<<操作符
在Gradle 5.1后已经废弃。
任务的执行分析
当我们执行一个任务的时候,其实就是执行其拥有的actions列表。这个列表保存在Task的对象实例中的actions成员变量中,其类型是List。
任务排序
通过任务的shouldRunAfter和mustRunAfter这两个方法,可以控制一个任务应该或者一定要在某个任务之后执行。
task task12{
doLast{
println 'task12'
}
}
task task13{
doLast{
println 'task13'
}
}
task12.mustRunAfter task13
任务的启用和禁用
Task中有个enabled属性,用于启用和禁用任务,默认为true,表示启用,设置为false,则禁止任务执行,输出会提示该任务被跳过。
task task14 {
doLast{
println 'task14'
}
}
task14.enabled = false
任务的onlyIf断言
Task有一个onlyIf方法,它接受一个闭包作为参数,如果该闭包返回true,则该任务执行,否则跳过。
以打渠道包为例。首发应用宝和百度,直接编译会打出所有包,执行时间长,不符合需求,可以采用onlyIf来控制:
final String BUILD_APP = "build_app"
final String BUILD_APPS_ALL = "all"
final String BUILD_APPS_SHOUFA = "shoufa"
final String BUILD_APPS_EXCLUDE_SHOUFA = "exclude_shoufa"
task(QQRelease).doLast{
println '打应用宝的包'
}
task(BaiduRelease).doLast{
println '打百度的包'
}
task(HuaWeiRelease).doLast{
println '打华为的包'
}
task(MIUIRelease).doLast{
println '打MIUI的包'
}
task build{
group BasePlugin.BUILD_GROUP
description "打渠道包"
}
build.dependsOn QQRelease,BaiduRelease,HuaWeiRelease,MIUIRelease
QQRelease.onlyIf{
def execute = false
if(project.hasProperty(BUILD_APP))
{
Object buildApp = project.property(BUILD_APP)
if(BUILD_APPS_SHOUFA.equals(buildApp)||BUILD_APPS_ALL.equals(buildApp))
{
execute = true
}
else{
execute = false
}
}
else{
execute = true
}
execute
}
BaiduRelease.onlyIf{
def execute = false
if(project.hasProperty(BUILD_APP))
{
Object buildApp = project.property(BUILD_APP)
if(BUILD_APPS_SHOUFA.equals(buildApp)||BUILD_APPS_ALL.equals(buildApp))
{
execute = true
}
else{
execute = false
}
}
else{
execute = true
}
execute
}
HuaWeiRelease.onlyIf{
def execute = false
if(project.hasProperty(BUILD_APP))
{
Object buildApp = project.property(BUILD_APP)
if(BUILD_APPS_EXCLUDE_SHOUFA.equals(buildApp)||BUILD_APPS_ALL.equals(buildApp))
{
execute = true
}
else{
execute = false
}
}
else{
execute = true
}
execute
}
MIUIRelease.onlyIf{
def execute = false
if(project.hasProperty(BUILD_APP))
{
Object buildApp = project.property(BUILD_APP)
if(BUILD_APPS_EXCLUDE_SHOUFA.equals(buildApp)||BUILD_APPS_ALL.equals(buildApp))
{
execute = true
}
else{
execute = false
}
}
else{
execute = true
}
execute
}
执行方式如下:
#打所有渠道包
gradle build
gradle -Pbuild_app=all build
#打首发包
gradle -Pbuild_app=shoufa build
#打非首发包
gradle -Pbuild_app=exclude_shoufa build
命令行中-P意思是为Project指定K-V格式的属性键值对,格式为-PK=V。
任务规则
tasks.addRule("对规则的描述"){
String taskName->
task(taskName) {
println "${taskName}任务不存在"
}
}
task task15{
dependsOn missTask
}