URI: 
       Properly handle -DEV suffix when comparing Hugo versions - hugo - [fork] hugo port for 9front
  HTML git clone git@git.drkhsh.at/hugo.git
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
   DIR README
   DIR LICENSE
       ---
   DIR commit 19d9a46f63a24b65c041be3f95053c154c78fd92
   DIR parent 0602135fd44b0cfa0a51b0ec6e451ae58ac95666
  HTML Author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
       Date:   Thu, 22 Feb 2018 17:16:42 +0100
       
       Properly handle -DEV suffix when comparing Hugo versions
       
       See #4443
       
       Diffstat:
         M helpers/hugo.go                     |      51 +++++++++++++++++++------------
         M helpers/hugo_test.go                |      10 ++++++++--
         M tpl/compare/compare_test.go         |       4 ++++
       
       3 files changed, 44 insertions(+), 21 deletions(-)
       ---
   DIR diff --git a/helpers/hugo.go b/helpers/hugo.go
       @@ -14,7 +14,6 @@
        package helpers
        
        import (
       -        "errors"
                "fmt"
                "strings"
        
       @@ -57,7 +56,7 @@ func (h HugoVersionString) String() string {
        // Implements compare.Comparer
        func (h HugoVersionString) Compare(other interface{}) int {
                v := MustParseHugoVersion(h.String())
       -        return compareVersions(v.Number, v.PatchLevel, other)
       +        return compareVersionsWithSuffix(v.Number, v.PatchLevel, v.Suffix, other)
        }
        
        // Implements compare.Eqer
       @@ -69,16 +68,16 @@ func (h HugoVersionString) Eq(other interface{}) bool {
                return s == h.String()
        }
        
       +var versionSuffixes = []string{"-test", "-DEV"}
       +
        // ParseHugoVersion parses a version string.
        func ParseHugoVersion(s string) (HugoVersion, error) {
                var vv HugoVersion
       -        if strings.HasSuffix(s, "-test") {
       -                vv.Suffix = "-test"
       -                s = strings.TrimSuffix(s, "-test")
       -        }
       -
       -        if strings.Contains(s, "DEV") {
       -                return vv, errors.New("DEV versions not supported by parse")
       +        for _, suffix := range versionSuffixes {
       +                if strings.HasSuffix(s, suffix) {
       +                        vv.Suffix = suffix
       +                        s = strings.TrimSuffix(s, suffix)
       +                }
                }
        
                v, p := parseVersion(s)
       @@ -141,39 +140,53 @@ func hugoVersion(version float32, patchVersion int, suffix string) string {
        // It returns -1 if the given version is less than, 0 if equal and 1 if greater than
        // the running version.
        func CompareVersion(version interface{}) int {
       -        return compareVersions(CurrentHugoVersion.Number, CurrentHugoVersion.PatchLevel, version)
       +        return compareVersionsWithSuffix(CurrentHugoVersion.Number, CurrentHugoVersion.PatchLevel, CurrentHugoVersion.Suffix, version)
        }
        
        func compareVersions(inVersion float32, inPatchVersion int, in interface{}) int {
       +        return compareVersionsWithSuffix(inVersion, inPatchVersion, "", in)
       +}
       +
       +func compareVersionsWithSuffix(inVersion float32, inPatchVersion int, suffix string, in interface{}) int {
       +        var c int
                switch d := in.(type) {
                case float64:
       -                return compareFloatVersions(inVersion, float32(d))
       +                c = compareFloatVersions(inVersion, float32(d))
                case float32:
       -                return compareFloatVersions(inVersion, d)
       +                c = compareFloatVersions(inVersion, d)
                case int:
       -                return compareFloatVersions(inVersion, float32(d))
       +                c = compareFloatVersions(inVersion, float32(d))
                case int32:
       -                return compareFloatVersions(inVersion, float32(d))
       +                c = compareFloatVersions(inVersion, float32(d))
                case int64:
       -                return compareFloatVersions(inVersion, float32(d))
       +                c = compareFloatVersions(inVersion, float32(d))
                default:
                        s, err := cast.ToStringE(in)
                        if err != nil {
                                return -1
                        }
        
       -                v, p := parseVersion(s)
       +                v, err := ParseHugoVersion(s)
       +                if err != nil {
       +                        return -1
       +                }
        
       -                if v == inVersion && p == inPatchVersion {
       -                        return 0
       +                if v.Number == inVersion && v.PatchLevel == inPatchVersion {
       +                        return strings.Compare(suffix, v.Suffix)
                        }
        
       -                if v < inVersion || (v == inVersion && p < inPatchVersion) {
       +                if v.Number < inVersion || (v.Number == inVersion && v.PatchLevel < inPatchVersion) {
                                return -1
                        }
        
                        return 1
                }
       +
       +        if c == 0 && suffix != "" {
       +                return 1
       +        }
       +
       +        return c
        }
        
        func parseVersion(s string) (float32, int) {
   DIR diff --git a/helpers/hugo_test.go b/helpers/hugo_test.go
       @@ -53,12 +53,18 @@ func TestCompareVersions(t *testing.T) {
                require.Equal(t, 1, compareVersions(0.20, 0, "0.20.1"))
                require.Equal(t, 1, compareVersions(0.20, 1, "0.20.2"))
                require.Equal(t, 1, compareVersions(0.21, 1, "0.22.1"))
       +        require.Equal(t, -1, compareVersions(0.22, 0, "0.22-DEV"))
       +        require.Equal(t, 1, compareVersions(0.22, 0, "0.22.1-DEV"))
       +        require.Equal(t, 1, compareVersionsWithSuffix(0.22, 0, "-DEV", "0.22"))
       +        require.Equal(t, -1, compareVersionsWithSuffix(0.22, 1, "-DEV", "0.22"))
       +        require.Equal(t, 0, compareVersionsWithSuffix(0.22, 1, "-DEV", "0.22.1-DEV"))
       +
        }
        
        func TestParseHugoVersion(t *testing.T) {
                require.Equal(t, "0.25", MustParseHugoVersion("0.25").String())
                require.Equal(t, "0.25.2", MustParseHugoVersion("0.25.2").String())
                require.Equal(t, "0.25-test", MustParseHugoVersion("0.25-test").String())
       -        _, err := ParseHugoVersion("0.25-DEV")
       -        require.Error(t, err)
       +        require.Equal(t, "0.25-DEV", MustParseHugoVersion("0.25-DEV").String())
       +
        }
   DIR diff --git a/tpl/compare/compare_test.go b/tpl/compare/compare_test.go
       @@ -180,6 +180,10 @@ func doTestCompare(t *testing.T, tp tstCompareType, funcUnderTest func(a, b inte
                        {helpers.MustParseHugoVersion("0.32").Version(), "0.36", -1},
                        {"0.36", helpers.MustParseHugoVersion("0.32").Version(), 1},
                        {"0.36", helpers.MustParseHugoVersion("0.36").Version(), 0},
       +                {"0.37", helpers.MustParseHugoVersion("0.37-DEV").Version(), 1},
       +                {"0.37-DEV", helpers.MustParseHugoVersion("0.37").Version(), -1},
       +                {"0.36", helpers.MustParseHugoVersion("0.37-DEV").Version(), -1},
       +                {"0.37-DEV", helpers.MustParseHugoVersion("0.37-DEV").Version(), 0},
                } {
                        result := funcUnderTest(test.left, test.right)
                        success := false