如何让Gradle将文件删除添加到日志输出?

时间:2014-06-25 18:45:05

标签: groovy gradle

我有一个包含多个文件删除步骤的Gradle脚本。运行脚本时,指定要删除的文件可能存在也可能不存在,因此仅添加println输出是不够的。我尝试使用TaskActionListener(),但似乎这个类只能在任务开始时完成并完成其操作,并且没有实际返回操作的详细信息。

我注意到Gradle的Delete任务类型包含一个名为getTargetFiles()的方法,这似乎是我正在寻找的方法,但我'我没有使用此任务 - 而是,我在其他更大的任务中使用以下语法:

delete file("$projectDir/javadoc")

以上对我的项目需要非常方便(我基本上试图将非常大的Ant构建转换为Gradle并且需要保持所有步骤相对相同而不是从头开始构建它,为了......很多其他人参与其中。

我突然想到我可以使用内置的AntBuilder(看看Ant通常如何输出它正在删除的内容),如下所示:

ant.delete(dir: "$projectDir/javadoc")

但似乎Gradle也会杀死它的输出!我很乐意使用-i选项运行脚本以进行INFO级别日志记录,但即使这样也不足以说服Gradle记录删除消息。只有-d才能解决问题,但当然我会因信息过载而受到轰炸。

有人有什么想法吗?我已经搜索了几天,但没有找到任何帮助。

1 个答案:

答案 0 :(得分:1)

你必须编写自己的方法。例如:

def delete(Object... paths) {
    for (file in project.files(paths)) {
        if (file.exists()) {
            println "Deleting $file"
        }
    }
    project.delete(paths)
}