2024-01-09 15:34:53 -06:00
|
|
|
package repostatus
|
|
|
|
|
2024-01-18 00:57:43 -06:00
|
|
|
import (
|
2024-02-12 06:23:31 -06:00
|
|
|
"fmt"
|
2024-01-09 15:34:53 -06:00
|
|
|
"os"
|
|
|
|
"os/exec"
|
2024-01-13 00:43:26 -06:00
|
|
|
"path/filepath"
|
2024-01-18 00:57:43 -06:00
|
|
|
"strings"
|
2024-02-12 06:23:31 -06:00
|
|
|
"time"
|
2024-01-09 15:34:53 -06:00
|
|
|
|
2024-11-08 06:43:33 -06:00
|
|
|
"github.com/go-cmd/cmd"
|
2024-02-12 18:16:03 -06:00
|
|
|
"go.wit.com/lib/gui/shell"
|
2024-01-09 15:34:53 -06:00
|
|
|
"go.wit.com/log"
|
|
|
|
)
|
|
|
|
|
2025-01-07 18:18:38 -06:00
|
|
|
/*
|
2024-01-11 15:56:50 -06:00
|
|
|
// goes in one directory so it gets remote branch names
|
2024-01-09 15:34:53 -06:00
|
|
|
func listFiles(directory string) []string {
|
|
|
|
var files []string
|
|
|
|
fileInfo, err := os.ReadDir(directory)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, file := range fileInfo {
|
2024-01-11 15:56:50 -06:00
|
|
|
if file.IsDir() {
|
|
|
|
dirname := file.Name()
|
|
|
|
newdir, _ := os.ReadDir(directory + "/" + dirname)
|
|
|
|
for _, file := range newdir {
|
2024-01-18 00:57:43 -06:00
|
|
|
if !file.IsDir() {
|
|
|
|
files = append(files, dirname+"/"+file.Name())
|
2024-01-11 15:56:50 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2024-01-09 15:34:53 -06:00
|
|
|
files = append(files, file.Name())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return files
|
|
|
|
}
|
2025-01-07 18:24:17 -06:00
|
|
|
*/
|
2024-01-09 19:35:05 -06:00
|
|
|
|
2025-01-07 18:24:17 -06:00
|
|
|
/*
|
2024-01-09 19:35:05 -06:00
|
|
|
func normalizeVersion(s string) string {
|
|
|
|
// reg, err := regexp.Compile("[^a-zA-Z0-9]+")
|
|
|
|
parts := strings.Split(s, "-")
|
2024-01-18 00:57:43 -06:00
|
|
|
if len(parts) == 0 {
|
|
|
|
return ""
|
|
|
|
}
|
2024-01-09 19:35:05 -06:00
|
|
|
reg, err := regexp.Compile("[^0-9.]+")
|
|
|
|
if err != nil {
|
|
|
|
log.Log(WARN, "normalizeVersion() regexp.Compile() ERROR =", err)
|
|
|
|
return parts[0]
|
|
|
|
}
|
|
|
|
clean := reg.ReplaceAllString(parts[0], "")
|
2024-01-23 10:52:17 -06:00
|
|
|
log.Log(INFO, "normalizeVersion() s =", clean)
|
2024-01-09 19:35:05 -06:00
|
|
|
return clean
|
|
|
|
}
|
2024-01-10 00:15:27 -06:00
|
|
|
|
|
|
|
func splitVersion(version string) (a, b, c string) {
|
|
|
|
tmp := normalizeVersion(version)
|
|
|
|
parts := strings.Split(tmp, ".")
|
|
|
|
switch len(parts) {
|
|
|
|
case 1:
|
|
|
|
return parts[0], "", ""
|
|
|
|
case 2:
|
|
|
|
return parts[0], parts[1], ""
|
|
|
|
default:
|
|
|
|
return parts[0], parts[1], parts[2]
|
|
|
|
}
|
|
|
|
}
|
2025-01-07 18:24:17 -06:00
|
|
|
*/
|
2024-01-10 18:18:01 -06:00
|
|
|
|
2024-11-08 06:43:33 -06:00
|
|
|
func (rs *RepoStatus) Run(cmd []string) cmd.Status {
|
2024-01-24 16:24:58 -06:00
|
|
|
path := rs.realPath.String()
|
2024-11-08 06:43:33 -06:00
|
|
|
r := shell.PathRun(path, cmd)
|
|
|
|
output := strings.Join(r.Stdout, "\n")
|
|
|
|
if r.Error != nil {
|
|
|
|
log.Log(WARN, "cmd:", cmd)
|
2024-01-24 16:24:58 -06:00
|
|
|
log.Log(WARN, "ouptput:", output)
|
2024-11-08 06:43:33 -06:00
|
|
|
log.Log(WARN, "failed with error:", r.Error)
|
2024-01-10 18:18:01 -06:00
|
|
|
}
|
2024-11-08 06:43:33 -06:00
|
|
|
return r
|
2024-01-10 18:18:01 -06:00
|
|
|
}
|
2024-01-13 00:43:26 -06:00
|
|
|
|
|
|
|
// Set the path to the package
|
|
|
|
func getfiles(pathToPackage string) {
|
|
|
|
// List files in the directory
|
|
|
|
err := filepath.Walk(pathToPackage, nil) // compiles but crashes
|
|
|
|
if err == nil {
|
2024-01-23 10:52:17 -06:00
|
|
|
log.Log(INFO, "directory ok", pathToPackage)
|
2024-01-13 00:43:26 -06:00
|
|
|
} else {
|
|
|
|
log.Warn("directory wrong", pathToPackage)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func IsDirectory(path string) bool {
|
|
|
|
info, err := os.Stat(path)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return info.IsDir()
|
|
|
|
}
|
|
|
|
|
2024-02-06 04:02:46 -06:00
|
|
|
func (rs *RepoStatus) Exists(filename string) bool {
|
2024-11-06 15:51:29 -06:00
|
|
|
if rs == nil {
|
|
|
|
log.Warn("rs == nil for Exists()")
|
|
|
|
panic(-1)
|
|
|
|
}
|
2024-03-09 22:03:18 -06:00
|
|
|
testf := filepath.Join(rs.Path(), filename)
|
2024-02-06 04:02:46 -06:00
|
|
|
if Exists(testf) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2024-02-22 17:19:29 -06:00
|
|
|
func (rs *RepoStatus) mtime(filename string) (time.Time, error) {
|
|
|
|
pathf := filepath.Join(rs.Path(), filename)
|
|
|
|
statf, err := os.Stat(pathf)
|
|
|
|
if err == nil {
|
|
|
|
return statf.ModTime(), nil
|
|
|
|
}
|
|
|
|
log.Log(REPOWARN, "mtime() error", pathf, err)
|
|
|
|
return time.Now(), err
|
|
|
|
}
|
|
|
|
|
2024-01-30 16:48:57 -06:00
|
|
|
// returns true if the file exists
|
|
|
|
func Exists(file string) bool {
|
|
|
|
_, err := os.Stat(file)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2024-02-12 06:23:31 -06:00
|
|
|
func getDurationStamp(t time.Time) string {
|
|
|
|
|
|
|
|
// Get the current time
|
|
|
|
currentTime := time.Now()
|
|
|
|
|
|
|
|
// Calculate the duration between t current time
|
|
|
|
duration := currentTime.Sub(t)
|
|
|
|
|
|
|
|
return formatDuration(duration)
|
|
|
|
}
|
|
|
|
|
|
|
|
func formatDuration(d time.Duration) string {
|
|
|
|
seconds := int(d.Seconds()) % 60
|
|
|
|
minutes := int(d.Minutes()) % 60
|
|
|
|
hours := int(d.Hours()) % 24
|
|
|
|
days := int(d.Hours()) / 24
|
2024-02-16 11:41:29 -06:00
|
|
|
years := int(d.Hours()) / (24 * 365)
|
2024-02-12 06:23:31 -06:00
|
|
|
|
|
|
|
result := ""
|
2024-02-16 11:41:29 -06:00
|
|
|
if years > 0 {
|
|
|
|
result += fmt.Sprintf("%dy ", years)
|
|
|
|
return result
|
|
|
|
}
|
2024-02-12 06:23:31 -06:00
|
|
|
if days > 0 {
|
|
|
|
result += fmt.Sprintf("%dd ", days)
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
if hours > 0 {
|
|
|
|
result += fmt.Sprintf("%dh ", hours)
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
if minutes > 0 {
|
|
|
|
result += fmt.Sprintf("%dm ", minutes)
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
if seconds > 0 {
|
|
|
|
result += fmt.Sprintf("%ds", seconds)
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
2024-02-12 15:27:40 -06:00
|
|
|
|
2024-02-15 22:50:50 -06:00
|
|
|
func (rs *RepoStatus) XtermNohup(cmdline string) {
|
|
|
|
shell.XtermCmd(rs.Path(), []string{cmdline})
|
|
|
|
}
|
|
|
|
func (rs *RepoStatus) Xterm(cmdline string) {
|
|
|
|
shell.XtermCmd(rs.Path(), []string{cmdline})
|
|
|
|
}
|
|
|
|
func (rs *RepoStatus) XtermWait(cmdline string) {
|
|
|
|
shell.XtermCmdWait(rs.Path(), []string{cmdline})
|
|
|
|
}
|
2024-02-16 11:41:29 -06:00
|
|
|
|
2024-02-15 22:50:50 -06:00
|
|
|
func (rs *RepoStatus) XtermBash(args []string) {
|
|
|
|
var argsX = []string{"-geometry", "120x40"}
|
|
|
|
tmp := strings.Join(args, " ") + ";bash"
|
|
|
|
argsX = append(argsX, "-e", "bash", "-c", tmp)
|
2024-02-12 21:50:54 -06:00
|
|
|
argsX = append(argsX, args...)
|
|
|
|
log.Info("xterm cmd=", argsX)
|
|
|
|
// set less to not exit on small diff's
|
|
|
|
os.Setenv("LESS", "-+F -+X -R")
|
|
|
|
cmd := exec.Command("xterm", argsX...)
|
|
|
|
path := rs.realPath.String()
|
|
|
|
cmd.Dir = path
|
|
|
|
if err := cmd.Run(); err != nil {
|
2024-02-16 21:20:52 -06:00
|
|
|
log.Log(WARN, "xterm.Run() failed")
|
|
|
|
log.Log(WARN, "path =", path)
|
|
|
|
log.Log(WARN, "cmd = xterm", argsX)
|
2024-02-12 21:50:54 -06:00
|
|
|
} else {
|
2024-02-16 21:20:52 -06:00
|
|
|
log.Log(WARN, "xterm.Run() worked")
|
|
|
|
log.Log(WARN, "path =", path)
|
|
|
|
log.Log(WARN, "cmd = xterm", argsX)
|
2024-02-12 21:50:54 -06:00
|
|
|
}
|
|
|
|
}
|
2024-02-14 00:09:58 -06:00
|
|
|
|
|
|
|
func (rs *RepoStatus) DoAll(all [][]string) bool {
|
|
|
|
for _, cmd := range all {
|
2024-02-16 21:20:52 -06:00
|
|
|
log.Log(WARN, "doAll() RUNNING: cmd =", cmd)
|
2024-11-08 06:43:33 -06:00
|
|
|
r := rs.Run(cmd)
|
|
|
|
if r.Error != nil {
|
|
|
|
log.Log(WARN, "doAll() err =", r.Error)
|
|
|
|
log.Log(WARN, "doAll() out =", r.Stdout)
|
2024-02-14 00:09:58 -06:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|