2019-07-22 20:46:48 +02:00
|
|
|
package calculator
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"strconv"
|
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
|
|
"github.com/Masterminds/semver"
|
2019-08-11 18:27:52 +02:00
|
|
|
"github.com/Nightapes/go-semantic-release/internal/shared"
|
2019-07-22 20:46:48 +02:00
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Calculator struct
|
|
|
|
|
type Calculator struct{}
|
|
|
|
|
|
|
|
|
|
// New Calculator struct
|
|
|
|
|
func New() *Calculator {
|
|
|
|
|
return &Calculator{}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//IncPrerelease increase prerelease by one
|
2020-01-26 17:08:57 +01:00
|
|
|
func (c *Calculator) IncPrerelease(preReleaseType string, version semver.Version) (semver.Version, error) {
|
2019-07-22 20:46:48 +02:00
|
|
|
defaultPrerelease := preReleaseType + ".0"
|
2020-01-26 17:08:57 +01:00
|
|
|
if !c.hasPrerelease(version, preReleaseType) {
|
2019-07-22 20:46:48 +02:00
|
|
|
return version.SetPrerelease(defaultPrerelease)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
parts := strings.Split(version.Prerelease(), ".")
|
|
|
|
|
if len(parts) == 2 {
|
|
|
|
|
i, err := strconv.Atoi(parts[1])
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Warnf("Could not parse release tag %s, use version %s", version.Prerelease(), version.String())
|
|
|
|
|
return version.SetPrerelease(defaultPrerelease)
|
|
|
|
|
}
|
2020-01-26 17:08:57 +01:00
|
|
|
return version.SetPrerelease(preReleaseType + "." + strconv.Itoa(i+1))
|
2019-07-22 20:46:48 +02:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
log.Warnf("Could not parse release tag %s, use version %s", version.Prerelease(), version.String())
|
|
|
|
|
return version.SetPrerelease(defaultPrerelease)
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-26 17:08:57 +01:00
|
|
|
func (c *Calculator) hasPrerelease(version semver.Version, preReleaseType string) bool {
|
|
|
|
|
if version.Prerelease() == "" || !strings.HasPrefix(version.Prerelease(), preReleaseType) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
|
2019-07-22 20:46:48 +02:00
|
|
|
//CalculateNewVersion from given commits and lastversion
|
2019-08-13 23:01:38 +02:00
|
|
|
func (c *Calculator) CalculateNewVersion(commits map[shared.Release][]shared.AnalyzedCommit, lastVersion *semver.Version, releaseType string, firstRelease bool) semver.Version {
|
2019-07-22 20:46:48 +02:00
|
|
|
switch releaseType {
|
2019-08-13 23:01:38 +02:00
|
|
|
case "beta", "alpha", "rc":
|
2020-01-26 17:08:57 +01:00
|
|
|
var version = *lastVersion
|
|
|
|
|
if !c.hasPrerelease(*lastVersion, releaseType) {
|
|
|
|
|
version, _ = c.inc(commits, lastVersion)
|
|
|
|
|
}
|
|
|
|
|
|
2019-07-22 20:46:48 +02:00
|
|
|
if len(commits["major"]) > 0 || len(commits["minor"]) > 0 || len(commits["patch"]) > 0 {
|
2020-01-26 17:08:57 +01:00
|
|
|
version, _ := c.IncPrerelease(releaseType, version)
|
2019-08-13 23:01:38 +02:00
|
|
|
return version
|
2019-07-22 20:46:48 +02:00
|
|
|
}
|
|
|
|
|
case "release":
|
|
|
|
|
if !firstRelease {
|
2019-09-03 21:34:00 +02:00
|
|
|
if lastVersion.Prerelease() != "" {
|
|
|
|
|
newVersion, _ := lastVersion.SetPrerelease("")
|
|
|
|
|
return newVersion
|
|
|
|
|
}
|
2020-01-26 17:08:57 +01:00
|
|
|
version, done := c.inc(commits, lastVersion)
|
|
|
|
|
if done {
|
|
|
|
|
return version
|
2019-07-22 20:46:48 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-13 23:01:38 +02:00
|
|
|
return *lastVersion
|
2019-07-22 20:46:48 +02:00
|
|
|
}
|
2020-01-26 17:08:57 +01:00
|
|
|
|
|
|
|
|
func (c *Calculator) inc(commits map[shared.Release][]shared.AnalyzedCommit, lastVersion *semver.Version) (semver.Version, bool) {
|
|
|
|
|
if len(commits["major"]) > 0 {
|
|
|
|
|
return lastVersion.IncMajor(), true
|
|
|
|
|
} else if len(commits["minor"]) > 0 {
|
|
|
|
|
return lastVersion.IncMinor(), true
|
|
|
|
|
} else if len(commits["patch"]) > 0 {
|
|
|
|
|
return lastVersion.IncPatch(), true
|
|
|
|
|
}
|
|
|
|
|
return semver.Version{}, false
|
|
|
|
|
}
|