2024-01-13 23:27:46 -06:00
|
|
|
package main
|
|
|
|
|
2024-01-18 00:58:14 -06:00
|
|
|
import (
|
2024-01-13 23:27:46 -06:00
|
|
|
"io/ioutil"
|
2024-01-30 21:54:51 -06:00
|
|
|
"os"
|
2024-01-30 13:09:24 -06:00
|
|
|
"os/user"
|
2024-01-30 21:54:51 -06:00
|
|
|
"path/filepath"
|
2024-01-13 23:27:46 -06:00
|
|
|
"strings"
|
2024-01-30 13:09:24 -06:00
|
|
|
|
|
|
|
"go.wit.com/gui"
|
|
|
|
"go.wit.com/lib/gadgets"
|
|
|
|
"go.wit.com/lib/gui/repostatus"
|
|
|
|
"go.wit.com/log"
|
2024-01-13 23:27:46 -06:00
|
|
|
)
|
|
|
|
|
2024-02-16 11:39:44 -06:00
|
|
|
// deprecate
|
|
|
|
func (r *repo) StringOld() string {
|
2024-01-18 05:03:04 -06:00
|
|
|
return r.status.String()
|
|
|
|
}
|
|
|
|
|
2024-02-16 01:18:58 -06:00
|
|
|
/*
|
2024-01-13 23:27:46 -06:00
|
|
|
func (r *repo) getPath() string {
|
|
|
|
return r.path
|
|
|
|
}
|
2024-02-16 01:18:58 -06:00
|
|
|
*/
|
2024-01-13 23:27:46 -06:00
|
|
|
|
|
|
|
func RemoveFirstElement(slice []string) (string, []string) {
|
|
|
|
if len(slice) == 0 {
|
|
|
|
return "", slice // Return the original slice if it's empty
|
|
|
|
}
|
|
|
|
return slice[0], slice[1:] // Return the slice without the first element
|
|
|
|
}
|
|
|
|
|
|
|
|
// returns path, master branch name, devel branch name, user branch name
|
|
|
|
func splitLine(line string) (string, string, string, string) {
|
|
|
|
var path, master, devel, user string
|
|
|
|
parts := strings.Split(line, " ")
|
|
|
|
path, parts = RemoveFirstElement(parts)
|
|
|
|
master, parts = RemoveFirstElement(parts)
|
|
|
|
devel, parts = RemoveFirstElement(parts)
|
|
|
|
user, parts = RemoveFirstElement(parts)
|
|
|
|
// path, master, devel, user := strings.Split(line, " ")
|
|
|
|
return path, master, devel, user
|
|
|
|
}
|
|
|
|
|
|
|
|
func myrepolist() []string {
|
2024-01-30 21:54:51 -06:00
|
|
|
homeDir, _ := os.UserHomeDir()
|
2024-02-16 11:39:44 -06:00
|
|
|
cfgfile := filepath.Join(homeDir, ".config/autotypist")
|
2024-01-30 21:54:51 -06:00
|
|
|
content, _ := ioutil.ReadFile(cfgfile)
|
2024-01-13 23:27:46 -06:00
|
|
|
out := string(content)
|
|
|
|
out = strings.TrimSpace(out)
|
|
|
|
lines := strings.Split(out, "\n")
|
|
|
|
return lines
|
|
|
|
}
|
2024-01-19 18:37:27 -06:00
|
|
|
|
2024-01-30 13:32:04 -06:00
|
|
|
// This creates a window
|
|
|
|
func repolistWindow() {
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin = gadgets.NewBasicWindow(me.myGui, "All git repositories in ~/go/src/")
|
|
|
|
me.reposwin.Make()
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposbox = me.reposwin.Box().NewBox("bw vbox", false)
|
|
|
|
// me.reposwin.Draw()
|
|
|
|
me.reposwin.Custom = func() {
|
2024-01-30 13:32:04 -06:00
|
|
|
log.Warn("GOT HERE: main() gadgets.NewBasicWindow() close")
|
|
|
|
log.Warn("Should I do something special here?")
|
|
|
|
}
|
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
repoAllButtons(me.reposbox)
|
2024-01-30 23:38:46 -06:00
|
|
|
|
2024-02-16 17:55:53 -06:00
|
|
|
me.reposgroup = me.reposbox.NewGroup("git repositories (configure in ~/.config/myrepolist)")
|
2024-02-12 15:24:35 -06:00
|
|
|
me.reposgrid = me.reposgroup.NewGrid("test", 0, 0)
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposgrid.NewLabel("") // path goes here
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposgrid.NewLabel("last tag").SetProgName("last tag")
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposgrid.NewLabel("master version")
|
|
|
|
me.reposgrid.NewLabel("devel version")
|
|
|
|
me.reposgrid.NewLabel("user version")
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposgrid.NewLabel("Status")
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposgrid.NewLabel("Current Version").SetProgName("Current Version")
|
2024-02-12 15:24:35 -06:00
|
|
|
me.reposgrid.NextRow()
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-01-30 21:54:51 -06:00
|
|
|
usr, _ := user.Current()
|
|
|
|
|
2024-01-30 13:32:04 -06:00
|
|
|
repos := myrepolist()
|
|
|
|
for _, line := range repos {
|
|
|
|
log.Verbose("repo =", line)
|
|
|
|
path, mbranch, dbranch, ubranch := splitLine(line)
|
|
|
|
if mbranch == "" {
|
|
|
|
mbranch = "master"
|
|
|
|
}
|
|
|
|
if dbranch == "" {
|
|
|
|
dbranch = "devel"
|
|
|
|
}
|
|
|
|
if ubranch == "" {
|
|
|
|
ubranch = usr.Username
|
|
|
|
}
|
2024-02-16 11:39:44 -06:00
|
|
|
newrepo := addRepo(me.reposgrid, path, mbranch, dbranch, ubranch)
|
|
|
|
if newrepo != nil {
|
|
|
|
// assume repos from ~/.config/autotypist file might be modified
|
|
|
|
newrepo.status.Writable()
|
|
|
|
}
|
2024-02-12 15:24:35 -06:00
|
|
|
me.reposgrid.NextRow()
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|
|
|
|
|
2024-02-15 22:46:35 -06:00
|
|
|
if args.OnlyMe {
|
|
|
|
log.Info("not scanning everything")
|
|
|
|
} else {
|
|
|
|
log.Info("scanning everything in ~/go/src")
|
|
|
|
for i, path := range repostatus.ListGitDirectories() {
|
|
|
|
// log.Info("addRepo()", i, path)
|
|
|
|
tmp := strings.TrimPrefix(path, me.goSrcPwd.String())
|
|
|
|
path = strings.Trim(tmp, "/")
|
|
|
|
log.Info("addRepo()", i, path)
|
|
|
|
addRepo(me.reposgrid, path, "master", "devel", usr.Username)
|
|
|
|
me.reposgrid.NextRow()
|
|
|
|
}
|
2024-02-14 13:24:37 -06:00
|
|
|
}
|
2024-01-30 23:38:46 -06:00
|
|
|
}
|
|
|
|
|
2024-02-12 21:51:51 -06:00
|
|
|
func showApps() {
|
2024-02-13 09:18:04 -06:00
|
|
|
for _, repo := range me.allrepos {
|
|
|
|
switch repo.status.RepoType() {
|
|
|
|
case "binary":
|
2024-02-16 01:18:58 -06:00
|
|
|
//log.Info("compile here. Show()")
|
2024-02-13 09:18:04 -06:00
|
|
|
repo.Show()
|
|
|
|
case "library":
|
2024-02-16 01:18:58 -06:00
|
|
|
//log.Info("library here. Hide()")
|
2024-02-13 09:18:04 -06:00
|
|
|
repo.Hide()
|
|
|
|
default:
|
2024-02-16 01:18:58 -06:00
|
|
|
log.Info("showApps() unknown. Show()")
|
2024-02-13 09:18:04 -06:00
|
|
|
repo.Hide()
|
2024-02-12 21:51:51 -06:00
|
|
|
}
|
2024-02-13 09:18:04 -06:00
|
|
|
|
|
|
|
}
|
2024-02-12 21:51:51 -06:00
|
|
|
}
|
|
|
|
|
2024-01-30 23:38:46 -06:00
|
|
|
func repoAllButtons(box *gui.Node) {
|
|
|
|
// reposbox.SetExpand(false)
|
|
|
|
group1 := box.NewGroup("Run on all repos:")
|
|
|
|
|
2024-02-07 15:24:59 -06:00
|
|
|
hbox := group1.Box()
|
|
|
|
// hbox.Horizontal()
|
|
|
|
hbox.Vertical()
|
|
|
|
|
|
|
|
box2 := hbox.Box().Vertical()
|
|
|
|
box2.NewButton("merge all user to devel", func() {
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Disable()
|
2024-02-06 04:03:17 -06:00
|
|
|
if !mergeAllUserToDevel() {
|
2024-02-02 15:22:48 -06:00
|
|
|
return
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Enable()
|
2024-01-30 13:32:04 -06:00
|
|
|
})
|
|
|
|
|
2024-02-07 15:24:59 -06:00
|
|
|
box2.NewButton("merge all devel to main", func() {
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Disable()
|
2024-02-06 04:03:17 -06:00
|
|
|
if !mergeAllDevelToMain() {
|
2024-02-02 15:22:48 -06:00
|
|
|
return
|
|
|
|
}
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Enable()
|
2024-02-02 15:22:48 -06:00
|
|
|
})
|
|
|
|
|
2024-02-07 15:24:59 -06:00
|
|
|
box2.NewButton("merge it all", func() {
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Disable()
|
2024-02-06 04:03:17 -06:00
|
|
|
if !mergeAllUserToDevel() {
|
2024-02-02 15:22:48 -06:00
|
|
|
return
|
|
|
|
}
|
2024-02-06 04:03:17 -06:00
|
|
|
if !mergeAllDevelToMain() {
|
2024-02-02 15:22:48 -06:00
|
|
|
return
|
|
|
|
}
|
2024-02-11 20:24:40 -06:00
|
|
|
me.reposwin.Enable()
|
2024-02-02 15:22:48 -06:00
|
|
|
})
|
|
|
|
|
2024-02-13 09:18:04 -06:00
|
|
|
box2.NewButton("test all builds", func() {
|
2024-02-12 21:51:51 -06:00
|
|
|
me.reposwin.Disable()
|
|
|
|
defer me.reposwin.Enable()
|
|
|
|
showApps()
|
|
|
|
for _, repo := range me.allrepos {
|
|
|
|
if repo.Hidden() {
|
|
|
|
// log.Info("skip hidden", repo.String())
|
|
|
|
} else {
|
|
|
|
log.Info("try to build", repo.String())
|
|
|
|
if repo.status.Build() {
|
|
|
|
log.Info("build worked", repo.String())
|
|
|
|
} else {
|
|
|
|
log.Info("build failed", repo.String())
|
2024-02-15 22:46:35 -06:00
|
|
|
go repo.status.Xterm("bash")
|
2024-02-12 21:51:51 -06:00
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
log.Info("")
|
|
|
|
log.Info("every build worked !!!")
|
|
|
|
log.Info("")
|
|
|
|
})
|
2024-02-02 15:22:48 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func mergeAllDevelToMain() bool {
|
|
|
|
log.Info("merge all here")
|
|
|
|
for _, repo := range me.allrepos {
|
|
|
|
if repo.status.ReadOnly() {
|
|
|
|
log.Info("skipping readonly", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.dirtyLabel.String() != "merge to main" {
|
|
|
|
log.Info("skipping. not merge to main", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.status.CheckDirty() {
|
|
|
|
log.Info("skipping dirty", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
log.Info("found", repo.String(), repo.dirtyLabel.String())
|
2024-02-16 20:37:23 -06:00
|
|
|
repo.newScan()
|
2024-02-16 21:20:13 -06:00
|
|
|
if repo.status.MergeUserToDevel() {
|
2024-02-02 15:22:48 -06:00
|
|
|
log.Warn("THINGS SEEM OK fullAutomation() returned true.")
|
|
|
|
} else {
|
2024-02-16 21:20:13 -06:00
|
|
|
log.Warn("last repo:", repo.status.Path())
|
2024-02-02 15:22:48 -06:00
|
|
|
log.Warn("THINGS FAILED fullAutomation() returned false")
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
repo.newScan()
|
|
|
|
}
|
|
|
|
log.Warn("EVERYTHING WORKED")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func mergeAllUserToDevel() bool {
|
2024-02-06 04:03:17 -06:00
|
|
|
log.Info("merge all here")
|
|
|
|
for _, repo := range me.allrepos {
|
|
|
|
if repo.status.ReadOnly() {
|
|
|
|
log.Info("skipping readonly", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.dirtyLabel.String() != "merge to devel" {
|
|
|
|
log.Info("skipping. not merge to devel", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.status.CheckDirty() {
|
|
|
|
log.Info("skipping dirty", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|
2024-02-06 04:03:17 -06:00
|
|
|
log.Info("found", repo.String(), repo.dirtyLabel.String())
|
2024-02-16 20:37:23 -06:00
|
|
|
repo.newScan()
|
2024-02-16 21:20:13 -06:00
|
|
|
if repo.status.MergeUserToDevel() {
|
2024-02-06 04:03:17 -06:00
|
|
|
log.Warn("THINGS SEEM OK fullAutomation() returned true.")
|
|
|
|
} else {
|
2024-02-16 21:20:13 -06:00
|
|
|
log.Warn("last repo:", repo.status.Path())
|
2024-02-06 04:03:17 -06:00
|
|
|
log.Warn("THINGS FAILED fullAutomation() returned false")
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
repo.newScan()
|
|
|
|
}
|
|
|
|
log.Warn("EVERYTHING WORKED")
|
|
|
|
return true
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|