summaryrefslogtreecommitdiffstats
path: root/releaser/releaser.go
diff options
context:
space:
mode:
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2017-07-05 10:23:07 +0200
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2017-07-05 14:27:43 +0200
commit5f831a622337d6a1d33a28a21391ba682030f21f (patch)
treea00afceacf5fb0d4460403c3f884da7c60a30195 /releaser/releaser.go
parente7a54e7afc21e647adc035b592638c77c8219fe2 (diff)
releaser: Replace the magic version handling
Take the new version as a string value.
Diffstat (limited to 'releaser/releaser.go')
-rw-r--r--releaser/releaser.go30
1 files changed, 11 insertions, 19 deletions
diff --git a/releaser/releaser.go b/releaser/releaser.go
index 52a74dc7e..52589e8b7 100644
--- a/releaser/releaser.go
+++ b/releaser/releaser.go
@@ -31,7 +31,7 @@ import (
const commitPrefix = "releaser:"
type ReleaseHandler struct {
- patch int
+ cliVersion string
// If set, we do the releases in 3 steps:
// 1: Create and write a draft release notes
@@ -62,24 +62,16 @@ func (r ReleaseHandler) shouldPrepareVersions() bool {
return r.step < 1 || r.step == 2
}
-func (r ReleaseHandler) calculateVersions(current helpers.HugoVersion) (helpers.HugoVersion, helpers.HugoVersion) {
- var (
- newVersion = current
- finalVersion = current
- )
+func (r ReleaseHandler) calculateVersions() (helpers.HugoVersion, helpers.HugoVersion) {
+
+ newVersion := helpers.MustParseHugoVersion(r.cliVersion)
+ finalVersion := newVersion
+ finalVersion.PatchLevel = 0
newVersion.Suffix = ""
- if r.shouldContinue() {
- // The version in the current code base is in the state we want for
- // the release.
- if r.patch == 0 {
- finalVersion = newVersion.Next()
- }
- } else if r.patch > 0 {
- newVersion = helpers.CurrentHugoVersion.NextPatchLevel(r.patch)
- } else {
- finalVersion = newVersion.Next()
+ if newVersion.PatchLevel == 0 {
+ finalVersion = finalVersion.Next()
}
finalVersion.Suffix = "-DEV"
@@ -87,8 +79,8 @@ func (r ReleaseHandler) calculateVersions(current helpers.HugoVersion) (helpers.
return newVersion, finalVersion
}
-func New(patch, step int, skipPublish, try bool) *ReleaseHandler {
- rh := &ReleaseHandler{patch: patch, step: step, skipPublish: skipPublish, try: try}
+func New(version string, step int, skipPublish, try bool) *ReleaseHandler {
+ rh := &ReleaseHandler{cliVersion: version, step: step, skipPublish: skipPublish, try: try}
if try {
rh.git = func(args ...string) (string, error) {
@@ -107,7 +99,7 @@ func (r *ReleaseHandler) Run() error {
return errors.New("GITHUB_TOKEN not set, create one here with the repo scope selected: https://github.com/settings/tokens/new")
}
- newVersion, finalVersion := r.calculateVersions(helpers.CurrentHugoVersion)
+ newVersion, finalVersion := r.calculateVersions()
version := newVersion.String()
tag := "v" + version