Compare commits

..

2 Commits

Author SHA1 Message Date
46e2d3166f Add version command
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
2022-11-22 12:54:03 -08:00
3437df8676 Add a way to check the minimum version supported by a LURE repo 2022-11-22 12:51:45 -08:00
7 changed files with 69 additions and 2 deletions

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
/lure /lure
/dist/ /dist/
/version.txt

View File

@ -1,6 +1,7 @@
before: before:
hooks: hooks:
- go mod tidy - go mod tidy
- go generate
builds: builds:
- id: lure - id: lure
env: env:

View File

@ -1,4 +1,4 @@
lure: lure: version.txt
go build go build
clean: clean:
@ -10,4 +10,7 @@ install: lure
uninstall: uninstall:
rm -f /usr/local/bin/lure rm -f /usr/local/bin/lure
version.txt:
go generate
.PHONY: install clean uninstall .PHONY: install clean uninstall

10
main.go
View File

@ -128,6 +128,11 @@ func main() {
Aliases: []string{"ref"}, Aliases: []string{"ref"},
Action: refreshCmd, Action: refreshCmd,
}, },
{
Name: "version",
Usage: "Display the current LURE version and exit",
Action: displayVersion,
},
}, },
} }
@ -136,3 +141,8 @@ func main() {
log.Error("Error while running app").Err(err).Send() log.Error("Error while running app").Err(err).Send()
} }
} }
func displayVersion(c *cli.Context) error {
print(version)
return nil
}

43
repo.go
View File

@ -41,6 +41,12 @@ func (p PkgNotFoundError) Error() string {
return "package '" + p.pkgName + "' could not be found in any repository" return "package '" + p.pkgName + "' could not be found in any repository"
} }
type RepoConfig struct {
Repo struct {
MinVersion string `toml:"minVersion"`
}
}
func addrepoCmd(c *cli.Context) error { func addrepoCmd(c *cli.Context) error {
name := c.String("name") name := c.String("name")
repoURL := c.String("url") repoURL := c.String("url")
@ -223,6 +229,26 @@ func pullRepos(ctx context.Context) error {
} else if err != nil { } else if err != nil {
return err return err
} }
fl, err := w.Filesystem.Open("lure-repo.toml")
if err != nil {
log.Warn("Git repository does not appear to be a valid LURE repo").Str("repo", repo.Name).Send()
continue
}
var repoCfg RepoConfig
err = toml.NewDecoder(fl).Decode(&repoCfg)
if err != nil {
return err
}
fl.Close()
currentVer, _, _ := strings.Cut(version, "-")
if vercmp(currentVer, repoCfg.Repo.MinVersion) == -1 {
log.Warn("LURE repo's minumum LURE version is greater than the current version. Try updating LURE if something doesn't work.").Str("repo", repo.Name).Send()
}
continue
} }
err = os.RemoveAll(repoDir) err = os.RemoveAll(repoDir)
@ -246,6 +272,23 @@ func pullRepos(ctx context.Context) error {
if err != nil { if err != nil {
return err return err
} }
fl, err := os.Open(filepath.Join(repoDir, "lure-repo.toml"))
if err != nil {
log.Warn("Git repository does not appear to be a valid LURE repo").Str("repo", repo.Name).Send()
}
var repoCfg RepoConfig
err = toml.NewDecoder(fl).Decode(&repoCfg)
if err != nil {
return err
}
fl.Close()
currentVer, _, _ := strings.Cut(version, "-")
if vercmp(currentVer, repoCfg.Repo.MinVersion) == -1 {
log.Warn("LURE repo's minumum LURE version is greater than the current version. Try updating LURE if something doesn't work.").Str("repo", repo.Name).Send()
}
} }
return nil return nil

3
scripts/gen-version.sh Executable file
View File

@ -0,0 +1,3 @@
#!/bin/bash
git describe --tags > version.txt

View File

@ -19,12 +19,18 @@
package main package main
import ( import (
_ "embed"
"strconv" "strconv"
"strings" "strings"
"golang.org/x/exp/slices" "golang.org/x/exp/slices"
) )
//go:generate scripts/gen-version.sh
//go:embed version.txt
var version string
// vercmp compares two version strings. // vercmp compares two version strings.
// It returns 1 if v1 is greater, // It returns 1 if v1 is greater,
// 0 if the versions are equal, // 0 if the versions are equal,