我目前正致力于将Ant脚本迁移到相应的Gradle版本。 一切正常,但自定义复制任务除外,该任务负责将生成的jar文件从build / libs复制到另一个目录(在项目之外)。
如果在第一次构建之后,我在任何java文件中引入了一个更改,并尝试执行
gradle clean build deploy
我看到构建/类* .class文件已正确更新,而build / libs / template-util.jar也是如此。但是,复制到/ home / fbudassi / Downloads的文件template-util.jar(大部分时间)都是该类的旧版本。有时,经过一些更改(我真的不知道在哪里,因为我尝试了很多东西),复制的jar会正确更新。
这是我的build.gradle:
apply plugin: 'java'
apply plugin: 'eclipse'
// Default task.
defaultTasks 'deploy'
// Configuration parameters.
group = 'com.rcs.template'
version = 'master'
sourceCompatibility = 1.7
targetCompatibility = 1.7
ext {
// Manifest extra parameters.
projectName = 'Template Util'
vendor = 'Rotterdam Community Solutions'
buildNumber = 10
jarName = 'template-util.jar'
// Dependencies versions.
jacksonVersion = '2.6.0'
// Deploy destinations.
deployTo = ['/home/fbudassi/Downloads']
}
// Dependencies.
dependencies {
compile "com.fasterxml.jackson.core:jackson-core:$jacksonVersion"
compile "com.fasterxml.jackson.core:jackson-annotations:$jacksonVersion"
compile "com.fasterxml.jackson.core:jackson-databind:$jacksonVersion"
compile "org.slf4j:slf4j-api:1.7.12"
compile "org.apache.commons:commons-lang3:3.4"
testCompile 'junit:junit:4.12'
}
repositories {
mavenCentral()
}
// Jar name and Manifest data.
jar {
def buildDate = new Date().format("MMMMM dd yyyy")
archiveName = jarName
manifest {
attributes 'Built-By': System.getProperty('user.name'),
'Built-Date': buildDate,
'Built-JDK': System.getProperty('java.version'),
'Implementation-Title': projectName,
'Implementation-Version': "$project.version - $buildDate - build: $buildNumber",
'Implementation-Vendor': vendor
}
}
// Deploy task: copy jar to destinations.
task deploy(dependsOn: 'build') {
deployTo.each { dest ->
copy {
from jar
into dest
}
}
}
// Gradle Wrapper version.
task wrapper(type: Wrapper) {
gradleVersion = '2.5'
}
你能帮我找到问题的答案吗?
答案 0 :(得分:1)
您必须在执行阶段执行复制操作。最快的修复可能会将任务操作放入doLast块中:
// Deploy task: copy jar to destinations.
task deploy(dependsOn: 'build') {
doLast {
deployTo.each { dest ->
copy {
from jar
into dest
}
}
}
}
否则您的复制操作将在配置阶段(创建新jar之前)执行,这就是为什么要复制旧的复制操作。通常,最好将设置切换为使用类型为copy的多个任务来进行部署。这也允许您可以从进行普通复制操作时未使用的最新检查中受益。
答案 1 :(得分:1)
除了在配置阶段部署jar这一事实(如Rene所写),您可以使用Copy
- DSL,Gradle Docs类型的任务,并从输出和向上获益迄今为止的机制:
task deploy(dependsOn: 'build', type: Copy) {
outputs.file(new File(dest)
from jar.outputs
into dest
}