大佬教程收集整理的这篇文章主要介绍了groovy – Gradle插件最佳实践,适用于依赖于扩展对象的任务,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
代码使用“project.afterEvaluate”来定义通过扩展对象配置所需设置时的任务.这似乎比应该更复杂.如果我将代码移出“afterEvaluate”,它将获得compileFlag == null,这不是外部设置.如果再次更改代码以使用<<或doLast语法,然后它将获得外部标志...但它无法使用类型:Exec和其他类似的有用类型. 我觉得我在某些方面与Gradle作战,这意味着我不太了解如何更好地与它合作.以下是我正在使用的简化伪代码.这有效,但我希望看看这是否可以简化,或者确实是最佳做法.此外,除非正在执行任务,否则不应抛出异常.
apply plugin: MyPlugin class MyPluginExtension { String compileFlag = null } class MyPlugin implements Plugin<Project> { void apply(Project project) { project.extensions.create("myPluginConfig",MyPluginExtension) project.afterEvaluate { // Closure delays getTing and checking flag until Strictly needed def compileFlag = { if (project.myPluginConfig.compileFlag == null) { throw new InvalidUserDataException( "Must set compileFlag: myPluginConfig { compileFlag = '-flag' }") } return project.myPluginConfig.compileFlag } // Inputs for translateTask def javaInputs = { project.files(project.fileTree( dir: project.projectDir,includes: ['**/*.java'])) } // This is the output of the first task and input to the second def translatedOutputs = { project.files(javaInputs().collect { file -> return file.path.replace('src/','build/dir/') }) } // Translates all java files into 'translatedOutputs' project.tasks.create(name: 'translateTask',type:ExeC) { inputs.files javaInputs() outputs.files translatedOutputs() executable '/bin/echo' inputs.files.each { file -> args file.path } } // Compiles 'translatedOutputs' to binary project.tasks.create(name: 'compileTask',type:Exec,dependsOn: 'translateTask') { inputs.files translatedOutputs() outputs.file project.file(project.buildDir.path + '/compiledBinary') executable '/bin/echo' args compileFlag() translatedOutputs().each { file -> args file.path } } } } }
另一种方法是使用您自己的sourceSets并将它们连接到您的自定义任务中.这还不够,IMO.我们仍在将JVM和源代码的本地表示结合在一起.
我建议将Exec任务作为自定义任务解压缩,并使用@TaskAction来完成繁重的任务(即使它只调用project.exec {}).然后,您可以使用@ Input,@ InputFiles等注释您的输入,并使用@OutputFiles,@ OutputDirectory等输出您的输出.这些注释将帮助自动连接您的依赖项和输入/输出(我认为这是一些战斗即将来临的地方)从).
你缺少的另一件事是如果compileFlag影响最终输出,你想要检测它的变化并强制重建(但不是重新翻译).
我使用Groovy .with method.简化了插件类的主体
我对此并不完全满意(我认为翻译的文件可能会有所不同),但我希望它能为您展示一些最佳实践.我把它作为一个工作的例子(只要你有一个src / something.java)通过将translate实现为一个复制/重命名而将compile编译为只创建一个’可执行’文件(内容只是输入列表) ).我还留下了你的扩展类来演示“全局”插件配置.另外看一下compileFlag没有设置会发生什么(我希望错误更好).
translateTask不会是增量的(虽然,我认为you could probably figure out a way to do that).所以你可能每次都需要删除输出目录.如果你想保持那么简单,我不会将其他输出混合到该目录中.
HTH
apply plugin: 'base' apply plugin: MyPlugin class myTranslateTask extends DefaultTask { @InputFiles FileCollection srcFiles @OutputDirectory File translatedDir @TaskAction public void translate() { // println "toolhome is ${project.myPluginConfig.toolHomE}" // translate java files by renaming them project.copy { includeEmptyDirs = false from(srcFiles) into(translatedDir) rename '(.+).java','$1.m' } } } class MyCompileTask extends DefaultTask { @Input String compileFlag @InputFiles FileCollection translatedFiles @OutputDirectory File outputDir @TaskAction public void compile() { // write inputs to the executable file project.file("$outputDir/executable") << "${project.myPluginConfig.toolHomE} $compileFlag ${translatedFiles.collect { it.path }}" } } class MyPluginExtension { File toolHome = new File("/some/sane/default") } class MyPlugin implements Plugin<Project> { void apply(Project project) { project.with { extensions.create("myPluginConfig",MyPluginExtension) tasks.create(name: 'translateTask',type: myTranslateTask) { description = "Translates all java files into translatedDir" srcFiles = fileTree(dir: projectDir,includes: [ '**/*.java' ]) translatedDir = file("${BuildDir}/dir") } tasks.create(name: 'compileTask',type: MyCompileTask) { description = "Compiles translated files into outputDir" translatedFiles = fileTree(tasks.translateTask.outputs.files.singleFilE) { includes [ '**/*.m' ] builtBy tasks.translateTask } outputDir = file("${BuildDir}/compiledBinary") } } } } myPluginConfig { toolHome = file("/some/custom/path") } compileTask { compileFlag = '-flag' }
以上是大佬教程为你收集整理的groovy – Gradle插件最佳实践,适用于依赖于扩展对象的任务全部内容,希望文章能够帮你解决groovy – Gradle插件最佳实践,适用于依赖于扩展对象的任务所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。