gitpb/gitTag.query.go

138 lines
3.6 KiB
Go
Raw Normal View History

package gitpb
// runs git, parses output
// types faster than you can
import (
2024-11-29 02:01:25 -06:00
"errors"
"path/filepath"
"strings"
"go.wit.com/log"
)
func (repo *Repo) GetLastTag() string {
cmd := []string{"git", "rev-list", "--tags", "--max-count=1"}
result := repo.RunQuiet(cmd)
2024-11-29 23:32:19 -06:00
// log.Info("getLastTagVersion()", result.Stdout)
if len(result.Stdout) != 1 {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "git LastTag() error:", result.Stdout)
return ""
}
hash := result.Stdout[0]
cmd = []string{"git", "describe", "--tags", "--always", hash}
result = repo.RunQuiet(cmd)
if len(result.Stdout) != 1 {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "git LastTag() error:", result.Stdout)
return ""
}
return result.Stdout[0]
}
2024-11-29 02:01:25 -06:00
func (repo *Repo) GitMasterVersion() string {
2024-11-29 21:51:30 -06:00
bname := repo.GetMasterBranchName()
v, err := repo.gitVersionByName(bname)
2024-11-29 02:01:25 -06:00
/*
2024-11-29 15:47:23 -06:00
count := repo.LenGitTags()
log.Info(repo.GoPath, "tag count", count)
repo.UpdateGitTags()
count = repo.LenGitTags()
log.Info(repo.GoPath, "tag count", count)
2024-11-29 02:01:25 -06:00
*/
if err == nil {
return v
} else {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "gitpb.GitMasterVersion() error:", err)
return ""
2024-11-29 02:01:25 -06:00
}
}
func (repo *Repo) GitDevelVersion() string {
2024-11-29 21:51:30 -06:00
bname := repo.GetDevelBranchName()
v, err := repo.gitVersionByName(bname)
2024-11-29 02:01:25 -06:00
if err == nil {
return v
} else {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "gitpb.GitDevelVersion() error:", err)
return ""
2024-11-29 02:01:25 -06:00
}
}
func (repo *Repo) GitUserVersion() string {
2024-11-29 21:51:30 -06:00
bname := repo.GetUserBranchName()
v, err := repo.gitVersionByName(bname)
2024-11-29 02:01:25 -06:00
if err == nil {
return v
} else {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "gitpb.GitUserVersion() error:", err)
return ""
2024-11-29 02:01:25 -06:00
}
}
func (repo *Repo) gitVersionByName(name string) (string, error) {
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 {
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "gitDescribeByName() output might have worked anyway:", output)
log.Log(GITPBWARN, "gitDescribeByName() not in a git repo?", r.Error, repo.GoPath)
return "", r.Error
}
2024-11-29 15:47:23 -06:00
return strings.TrimSpace(output), nil
}
2024-11-29 23:19:09 -06:00
if !repo.IsBranch(name) {
// tag does not exist
2024-11-29 15:47:23 -06:00
log.Log(GITPBWARN, "LocalTagExists()", name, "did not exist")
return "", errors.New("gitDescribeByName() git fatal: Not a valid object name: " + 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 15:47:23 -06:00
log.Log(GITPBWARN, "cmd =", cmd)
log.Log(GITPBWARN, "err =", result.Error)
log.Log(GITPBWARN, "output (might have worked with error?) =", output)
log.Log(GITPBWARN, "not in a git repo or bad tag?", repo.GoPath)
return "", result.Error
}
2024-11-29 15:47:23 -06:00
return strings.TrimSpace(output), nil
}
2024-11-29 15:47:23 -06:00
// find a branch name
// will find "master" or "devel"
// will also find "v0.1.1"
// or will find "patches-from-foo"
// will return *any* match on any git branch because it doesn't
// matter much here yet
// eventually this will be worked out by forge in some future code that hasn't been made yet
func (repo *Repo) IsBranch(findname string) bool {
loop := repo.Tags.All()
2024-11-29 02:01:25 -06:00
for loop.Scan() {
t := loop.Next()
// log.Info("LocalTagExists() tag:", t.Refname)
2024-11-29 02:01:25 -06:00
tagname := t.Refname
if strings.HasPrefix(tagname, "refs/remotes") {
continue
}
path, filename := filepath.Split(tagname)
2024-11-29 15:47:23 -06:00
log.Log(GITPB, "gitpb.IsBranch() tag:", path, filename, "from", repo.GoPath)
if filename == findname {
2024-11-29 15:47:23 -06:00
log.Log(GITPB, "gitpb.IsBranch() found tag:", path, filename, "from", repo.GoPath)
return true
}
}
2024-11-29 21:51:30 -06:00
log.Log(GITPB, "did not find tag:", findname, "in", repo.GoPath)
return false
}