1
0
Fork 0
mirror of https://github.com/ethauvin/kobalt.git synced 2025-04-25 07:57:12 -07:00

Added push parameter to autoGitTag.

This commit is contained in:
Erik C. Thauvin 2017-05-10 11:46:41 -07:00
parent a38b05fc92
commit b944039fdc
2 changed files with 11 additions and 5 deletions

View file

@ -6,10 +6,11 @@ import com.google.inject.Inject
import java.io.File
class Git @Inject constructor() {
fun maybeTagRelease(project: Project, uploadResult: TaskResult, enabled: Boolean, annotated: Boolean, tag: String, message: String) : TaskResult {
fun maybeTagRelease(project: Project, uploadResult: TaskResult, enabled: Boolean, annotated: Boolean,
push: Boolean, tag: String, message: String) : TaskResult {
val result =
if (uploadResult.success && enabled) {
val tagSuccess = tagRelease(project, annotated, tag, message)
val tagSuccess = tagRelease(project, annotated, push, tag, message)
if (! tagSuccess) {
TaskResult(false, errorMessage = "Couldn't tag the project")
} else {
@ -21,7 +22,7 @@ class Git @Inject constructor() {
return result
}
private fun tagRelease(project: Project, annotated: Boolean, tag: String, message: String) : Boolean {
private fun tagRelease(project: Project, annotated: Boolean, push: Boolean, tag: String, message: String) : Boolean {
val version = if (tag.isNullOrBlank()) project.version else tag
val success = try {
log(2, "Tagging this release as \"$version\"")
@ -37,7 +38,9 @@ class Git @Inject constructor() {
} else {
git.tag().setName(version).setMessage(message).call()
}
if (push) {
git.push().setPushTags().call()
}
true
} catch(ex: Exception) {
warn("Couldn't create tag ${version}: ${ex.message}", ex)

View file

@ -47,7 +47,7 @@ class PublishPlugin @Inject constructor(val files: KFiles, val factory: PomGener
private fun autoGitTag(project: Project, uploadResult: TaskResult, config: AutoGitTagConfig?) : TaskResult {
if (config != null) {
with(config) {
return git.maybeTagRelease(project, uploadResult, enabled, annotated, tag, message)
return git.maybeTagRelease(project, uploadResult, enabled, annotated, push, tag, message)
}
} else {
return TaskResult()
@ -222,6 +222,9 @@ data class AutoGitTagConfig(val project: Project) {
@Directive
var annotated: Boolean = false
@Directive
var push: Boolean = true
@Directive
var tag : String = project.version!!