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

3
.gitignore vendored
View File

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

View File

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

View File

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

10
main.go
View File

@ -128,6 +128,11 @@ func main() {
Aliases: []string{"ref"},
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()
}
}
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"
}
type RepoConfig struct {
Repo struct {
MinVersion string `toml:"minVersion"`
}
}
func addrepoCmd(c *cli.Context) error {
name := c.String("name")
repoURL := c.String("url")
@ -223,6 +229,26 @@ func pullRepos(ctx context.Context) error {
} else if err != nil {
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)
@ -246,6 +272,23 @@ func pullRepos(ctx context.Context) error {
if err != nil {
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

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
import (
_ "embed"
"strconv"
"strings"
"golang.org/x/exp/slices"
)
//go:generate scripts/gen-version.sh
//go:embed version.txt
var version string
// vercmp compares two version strings.
// It returns 1 if v1 is greater,
// 0 if the versions are equal,