diff options
author | zeripath <art27@cantab.net> | 2020-10-21 17:42:08 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-21 17:42:08 +0200 |
commit | de6e427a0188ef1be6108c5a71979dc4dd679aec (patch) | |
tree | ac0d5a17dcac25c4a6f702b6949123d527027002 /modules/git/git.go | |
parent | [skip ci] Updated translations via Crowdin (diff) | |
download | forgejo-de6e427a0188ef1be6108c5a71979dc4dd679aec.tar.xz forgejo-de6e427a0188ef1be6108c5a71979dc4dd679aec.zip |
go-version constraints ignore pre-releases (#13234)
Go-version constraints ignore pre-releases.
Rather than change the library further this PR simply changes
the git version comparison to use simple version compare ignoring the
issue of pre-releases.
Signed-off-by: Andrew Thornton <art27@cantab.net>
Diffstat (limited to 'modules/git/git.go')
-rw-r--r-- | modules/git/git.go | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/modules/git/git.go b/modules/git/git.go index a9ff923cc5..cce5cc738d 100644 --- a/modules/git/git.go +++ b/modules/git/git.go @@ -150,13 +150,13 @@ func Init(ctx context.Context) error { return err } - if CheckGitVersionConstraint(">= 2.10") == nil { + if CheckGitVersionAtLeast("2.10") == nil { if err := checkAndSetConfig("receive.advertisePushOptions", "true", true); err != nil { return err } } - if CheckGitVersionConstraint(">= 2.18") == nil { + if CheckGitVersionAtLeast("2.18") == nil { if err := checkAndSetConfig("core.commitGraph", "true", true); err != nil { return err } @@ -173,17 +173,17 @@ func Init(ctx context.Context) error { return nil } -// CheckGitVersionConstraint check version constrain against local installed git version -func CheckGitVersionConstraint(constraint string) error { +// CheckGitVersionAtLeast check git version is at least the constraint version +func CheckGitVersionAtLeast(atLeast string) error { if err := LoadGitVersion(); err != nil { return err } - check, err := version.NewConstraint(constraint) + atLeastVersion, err := version.NewVersion(atLeast) if err != nil { return err } - if !check.Check(gitVersion) { - return fmt.Errorf("installed git binary %s does not satisfy version constraint %s", gitVersion.Original(), constraint) + if gitVersion.Compare(atLeastVersion) < 0 { + return fmt.Errorf("installed git binary version %s is not at least %s", gitVersion.Original(), atLeast) } return nil } |