为什么0000在gradle foo之后不退出?在删除doFirst foo.doFirst{ delete '0000' }之后,0000就在那里了。
doFirst应该在foo任务脚本之前执行。

文档说:

Task doFirst(Closure action)

Adds the given closure to the beginning of this task's action list. The closure is passed this task as a parameter when executed.

完整的命令日志:
isaac-mbp:swap isaac$ cat build.gradle
task foo {
    mkdir '0000/a'
    mkdir '0000/b'
}
foo.doFirst{ delete '0000' }

isaac-mbp:swap isaac$ gradle foo
:foo

BUILD SUCCESSFUL

Total time: 0.581 secs
isaac-mbp:swap isaac$ ls -lha 0000
ls: cannot access 0000: No such file or directory
isaac-mbp:swap isaac$ gradle -v

------------------------------------------------------------
Gradle 2.14
------------------------------------------------------------

Build time:   2016-06-14 07:16:37 UTC
Revision:     cba5fea19f1e0c6a00cc904828a6ec4e11739abc

Groovy:       2.4.4
Ant:          Apache Ant(TM) version 1.9.6 compiled on June 29 2015
JVM:          1.8.0_25 (Oracle Corporation 25.25-b02)
OS:           Mac OS X 10.11.5 x86_64

最佳答案

没有。

  • 任务是(简化)为按顺序添加操作而执行的操作的集合
  • build.gradle分两个阶段运行:配置和执行。

  • 由于在配置时间中添加了mkdir,因此每次执行以下代码时,都会执行以下代码中的逻辑(build.gradle):
    task foo {
        mkdir '0000/a'
        mkdir '0000/b'
    }
    

    要解决此问题-添加操作:
    task foo << {
        mkdir '0000/a'
        mkdir '0000/b'
    }
    

    现在doFirst:
    task foo << {
            mkdir '0000/a'
            mkdir '0000/b'
    }
    foo.doFirst { delete '0000' }
    

    现在,该任务具有2个 Action :mkdirsdelete,它们将以适当的顺序执行。也请看看here

    关于gradle - 什么时候doFirst在gradle中执行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38493784/

    10-11 22:15
    查看更多