Gradle之恋-任务1

任务作为Gradle的核心功能模块,而且Gradle的任务还可以具有自己的属性和方法,大大扩展了Ant任务的功能。由于任务相关内容比较多,分为两篇来探讨,本篇主要涉及到:任务的定义、任务的属性、任务的配置、任务间依赖。

gradle

创建demo项目

为了本文演示的顺利运行,创建一个demo,名为gradle-tasks

mkdir gradle-tasks && cd gradle-tasks && gradle init

<small>由于我没有windows环境,windows环境的朋友可仿照上面:创建文件夹->进入文件夹->执行gradle init任务。</small>

任务定义

Gradle的任务定义除了关键词定义,还有几个变种,是为了使用某些场合而设计的,如关键词定义不支持表达式等。实际上创建任务是调用org.gradle.api.tasks.TaskContainer的create方法,TaskContainer中的方法签名如下,因此这玩意最好不要死记硬背,忘记了就查下dsl文档

taskcontainer-method

关键词方式

编辑build.gradle,添加任务

task helloWorld {
    doLast {
        println "hello world!"
    }   
}
任务执行

执行任务的语法是

gradle [option...] [task...]

其中有个选项是quiet简写为q,只记录错误信息,用于输出简洁的回显。执行上面关键词的任务

gradle helloWorld

回显

Starting a Gradle Daemon (subsequent builds will be faster) :hello hello world!

gradle -q helloWorld

回显

hello world!

如果你的任务名称是驼峰格式,还可以使用简写如执行helloWorld

gradle -q hW
关键词-字符串
task 'str'{
    doLast{
        println 'this is a str task';
    }
}
函数式-关键词
task(testName){
    doLast{
        println "my names is zhaiqianfeng."
    }   
}
函数式-字符串
task('testString'){
    doLast{
        println "This is a string task."
    }   
}
函数式-map
tasks.create(name:'testMap'){
    doLast{
        println "This is a map task."
    }   
}

当然你还可以使用更多参数如type,configuration等,具体值可以参考dsl文档,如

task('copy', type: Copy) {
    from(file('srcDir'))
    into(buildDir)
}
任务属性

经常会对你定义的任务进行一些配置或定义依赖的操作,这就需要能够访问到它们。每个任务都是作为项目的属性(property)

println helloWorld.name
println project.helloWorld.name

也可以通过任务集合来访问任务

println tasks['helloWorld'].name
println tasks.helloWorld.name

也可以通过getByPath访问任何项目的任务,":"代表根路径

println tasks.getByPath('helloWorld').path
println tasks.getByPath(':helloWorld').path

我们在build script中添加任务来测试

task accessTask{
    doLast{
        println helloWorld.name
        println project.helloWorld.name
        println tasks['helloWorld'].name
        println tasks.helloWorld.name
        println tasks.getByPath('helloWorld').path
        println tasks.getByPath(':helloWorld').path
    }   
}

执行

$ gradle -q aT helloWorld helloWorld helloWorld helloWorld :helloWorld :helloWorld

配置任务

可以先定义一个没有任何行为的任务,后期配置,如

task config

config {
    doLast{
        println "this is a config task."
    }   
}

你也可以使用变量的方式来配置

Task cf=task('config')
cf.doLast{
    println 'this is added by var.'
}
config.doLast{
    println 'this is added by name.'
}
任务依赖

任务之间可以有依赖关系,当执行该任务时,会先执行其依赖的任务。任务之间的依赖通过dependsOn关键词来设定。

task hello{
    doLast{
        print 'hello '
    }   
}
task world(dependsOn:hello){
    doLast{
        println 'world!'
    }   
}

如果依赖的顺序颠倒则必须使用字符串了,否则会找不到的异常:

task world(dependsOn:'hello'){
    doLast{
        println 'world!'
    }   
}

task hello{
    doLast{
        print 'hello '
    }   
}

当然也可以用属性的方式添加行为

task world{
    doLast{
        println 'world!'
    }
}

world.dependsOn{'hello'}

task hello{
    doLast{
        print 'hello '
    }
}

未完待续....


更多原创文章可关注我的个人博客:宅前疯 或微信公众账号:zhaiqianfeng

微信公众号:zhaiqianfeng

转载于:https://my.oschina.net/u/3338653/blog/855484

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值