2024-11-29 01:23:51 -06:00
|
|
|
package gitpb
|
|
|
|
|
|
|
|
// runs git, parses output
|
|
|
|
// types faster than you can
|
|
|
|
|
|
|
|
import (
|
2024-11-29 02:01:25 -06:00
|
|
|
"errors"
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
|
2024-11-29 01:23:51 -06:00
|
|
|
"go.wit.com/log"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (repo *Repo) GetLastTag() string {
|
|
|
|
cmd := []string{"git", "rev-list", "--tags", "--max-count=1"}
|
|
|
|
result := repo.RunQuiet(cmd)
|
|
|
|
log.Info("getLastTagVersion()", result.Stdout)
|
|
|
|
|
|
|
|
if len(result.Stdout) != 1 {
|
|
|
|
log.Info("git LastTag() error:", result.Stdout)
|
|
|
|
return "error"
|
|
|
|
}
|
|
|
|
|
|
|
|
hash := result.Stdout[0]
|
|
|
|
|
|
|
|
cmd = []string{"git", "describe", "--tags", "--always", hash}
|
|
|
|
result = repo.RunQuiet(cmd)
|
|
|
|
|
|
|
|
if len(result.Stdout) != 1 {
|
|
|
|
log.Info("git LastTag() error:", result.Stdout)
|
|
|
|
return "error"
|
|
|
|
}
|
|
|
|
|
|
|
|
return result.Stdout[0]
|
|
|
|
}
|
|
|
|
|
2024-11-29 02:01:25 -06:00
|
|
|
func (repo *Repo) GitMasterVersion() string {
|
|
|
|
v, err := repo.gitVersionByName("master")
|
|
|
|
/*
|
|
|
|
count := repo.LenGitTags()
|
|
|
|
log.Info(repo.GoPath, "tag count", count)
|
|
|
|
repo.UpdateGitTags()
|
|
|
|
count = repo.LenGitTags()
|
|
|
|
log.Info(repo.GoPath, "tag count", count)
|
|
|
|
*/
|
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
return v
|
|
|
|
} else {
|
|
|
|
log.Info("GitMasterVersion() error", err)
|
|
|
|
return "error"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) GitDevelVersion() string {
|
|
|
|
v, err := repo.gitVersionByName("devel")
|
|
|
|
if err == nil {
|
|
|
|
return v
|
|
|
|
} else {
|
|
|
|
log.Info("GitMasterVersion() error", err)
|
|
|
|
return "error"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) GitUserVersion() string {
|
|
|
|
v, err := repo.gitVersionByName("jcarr")
|
|
|
|
if err == nil {
|
|
|
|
return v
|
|
|
|
} else {
|
|
|
|
log.Info("GitMasterVersion() error", err)
|
|
|
|
return "error"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) gitVersionByName(name string) (string, error) {
|
2024-11-29 01:23:51 -06:00
|
|
|
name = strings.TrimSpace(name)
|
|
|
|
|
|
|
|
if name == "" {
|
|
|
|
// git will return the current tag
|
|
|
|
r := repo.RunQuiet([]string{"git", "describe", "--tags", "--always"})
|
|
|
|
output := strings.Join(r.Stdout, "\n")
|
|
|
|
if r.Error != nil {
|
|
|
|
log.Warn("gitDescribeByName() not in a git repo?", r.Error, repo.GoPath)
|
|
|
|
}
|
|
|
|
return strings.TrimSpace(output), r.Error
|
|
|
|
}
|
|
|
|
if !repo.LocalTagExists(name) {
|
|
|
|
// tag does not exist
|
2024-11-29 02:01:25 -06:00
|
|
|
log.Warn("LocalTagExists()", name, "did not exist")
|
2024-11-29 01:23:51 -06:00
|
|
|
return "", errors.New("gitDescribeByName() git fatal: Not a valid object name")
|
|
|
|
}
|
|
|
|
cmd := []string{"git", "describe", "--tags", "--always", name}
|
2024-11-29 02:01:25 -06:00
|
|
|
result := repo.RunQuiet(cmd)
|
|
|
|
output := strings.Join(result.Stdout, "\n")
|
|
|
|
if result.Error != nil {
|
2024-11-29 01:23:51 -06:00
|
|
|
log.Warn("cmd =", cmd)
|
2024-11-29 02:01:25 -06:00
|
|
|
log.Warn("err =", result.Error)
|
|
|
|
log.Warn("not in a git repo or bad tag?", repo.GoPath)
|
2024-11-29 01:23:51 -06:00
|
|
|
}
|
|
|
|
|
2024-11-29 02:01:25 -06:00
|
|
|
return strings.TrimSpace(output), result.Error
|
2024-11-29 01:23:51 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func (repo *Repo) LocalTagExists(findname string) bool {
|
2024-11-29 02:01:25 -06:00
|
|
|
loop := repo.AllTags()
|
|
|
|
for loop.Scan() {
|
|
|
|
t := loop.Next()
|
2024-11-29 02:20:44 -06:00
|
|
|
// log.Info("LocalTagExists() tag:", t.Refname)
|
2024-11-29 02:01:25 -06:00
|
|
|
|
|
|
|
tagname := t.Refname
|
2024-11-29 01:23:51 -06:00
|
|
|
if strings.HasPrefix(tagname, "refs/remotes") {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
path, filename := filepath.Split(tagname)
|
2024-11-29 02:20:44 -06:00
|
|
|
log.Log(GITPB, "LocalTagExists() tag:", path, filename, "from", repo.GoPath)
|
2024-11-29 01:23:51 -06:00
|
|
|
if filename == findname {
|
2024-11-29 02:20:44 -06:00
|
|
|
log.Log(GITPB, "found tag:", path, filename, "from", repo.GoPath)
|
2024-11-29 01:23:51 -06:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
2024-11-29 02:20:44 -06:00
|
|
|
log.Log(GITPBWARN, "did not find tag:", findname, "in", repo.GoPath)
|
2024-11-29 01:23:51 -06:00
|
|
|
return false
|
|
|
|
}
|