2024-01-13 23:27:46 -06:00
|
|
|
// This is a simple example
|
|
|
|
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-01-18 05:03:04 -06:00
|
|
|
func (r *repo) String() string {
|
|
|
|
return r.status.String()
|
|
|
|
}
|
|
|
|
|
2024-01-13 23:27:46 -06:00
|
|
|
func (r *repo) getPath() string {
|
|
|
|
return r.path
|
|
|
|
}
|
|
|
|
|
|
|
|
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()
|
|
|
|
cfgfile := filepath.Join(homeDir, ".config/myrepolist")
|
|
|
|
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
|
|
|
|
|
|
|
func (r *repo) Hide() {
|
|
|
|
r.pLabel.Hide()
|
|
|
|
r.lastTag.Hide()
|
|
|
|
r.vLabel.Hide()
|
|
|
|
|
|
|
|
r.masterVersion.Hide()
|
|
|
|
r.develVersion.Hide()
|
|
|
|
r.userVersion.Hide()
|
2024-01-20 18:45:55 -06:00
|
|
|
|
2024-01-19 18:37:27 -06:00
|
|
|
r.dirtyLabel.Hide()
|
2024-01-23 11:22:33 -06:00
|
|
|
r.statusButton.Hide()
|
2024-01-19 18:37:27 -06:00
|
|
|
r.hidden = true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *repo) Show() {
|
|
|
|
r.pLabel.Show()
|
|
|
|
r.lastTag.Show()
|
|
|
|
r.vLabel.Show()
|
|
|
|
|
|
|
|
r.masterVersion.Show()
|
|
|
|
r.develVersion.Show()
|
|
|
|
r.userVersion.Show()
|
2024-01-20 18:45:55 -06:00
|
|
|
|
2024-01-19 18:37:27 -06:00
|
|
|
r.dirtyLabel.Show()
|
2024-01-23 11:22:33 -06:00
|
|
|
r.statusButton.Show()
|
2024-01-19 18:37:27 -06:00
|
|
|
r.hidden = false
|
|
|
|
}
|
2024-01-30 13:09:24 -06:00
|
|
|
|
|
|
|
func addRepo(grid *gui.Node, path string, master string, devel string, user string) {
|
|
|
|
_, ok := me.allrepos[path]
|
|
|
|
if ok {
|
|
|
|
log.Info("addRepo() already had path", path)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
newRepo := new(repo)
|
|
|
|
|
|
|
|
path = strings.Trim(path, "/") // trim any extranous '/' chars put in the config file by the user
|
|
|
|
if path == "" {
|
|
|
|
log.Warn("addRepo() got empty path", path, master, devel, user)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if repostatus.VerifyLocalGoRepo(path) {
|
|
|
|
log.Verbose("newRepo actually exists", newRepo.getPath())
|
|
|
|
} else {
|
|
|
|
log.Warn("repostatus.VerifyLocalGoRepo() failed for for", path, master, devel, user)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
newRepo.path = path
|
|
|
|
newRepo.pLabel = grid.NewLabel(path).SetProgName("path")
|
|
|
|
|
|
|
|
newRepo.lastTag = grid.NewLabel("").SetProgName("lastTag")
|
|
|
|
|
|
|
|
newRepo.masterVersion = grid.NewLabel("").SetProgName("masterVersion")
|
|
|
|
newRepo.develVersion = grid.NewLabel("").SetProgName("develVersion")
|
|
|
|
newRepo.userVersion = grid.NewLabel("").SetProgName("userVersion")
|
|
|
|
|
|
|
|
newRepo.dirtyLabel = grid.NewLabel("")
|
|
|
|
|
|
|
|
newRepo.vLabel = grid.NewLabel("").SetProgName("current")
|
|
|
|
|
|
|
|
newRepo.statusButton = grid.NewButton("Configure", func() {
|
|
|
|
if newRepo.status == nil {
|
|
|
|
log.Warn("status window doesn't exist")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.Warn("status window exists. trying TestDraw() here")
|
|
|
|
newRepo.status.Toggle()
|
|
|
|
})
|
|
|
|
|
|
|
|
newRepo.status = repostatus.NewRepoStatusWindow(newRepo.path)
|
|
|
|
newRepo.hidden = false
|
|
|
|
newRepo.status.SetMainWorkingName(master)
|
|
|
|
newRepo.status.SetDevelWorkingName(devel)
|
|
|
|
newRepo.status.SetUserWorkingName(user)
|
2024-01-31 08:47:08 -06:00
|
|
|
|
2024-01-30 13:09:24 -06:00
|
|
|
me.allrepos[path] = newRepo
|
|
|
|
}
|
2024-01-30 13:32:04 -06:00
|
|
|
|
|
|
|
// This creates a window
|
|
|
|
func repolistWindow() {
|
|
|
|
reposwin = gadgets.NewBasicWindow(me.myGui, "All git repositories in ~/go/src/")
|
|
|
|
reposwin.Make()
|
|
|
|
|
|
|
|
reposbox = reposwin.Box().NewBox("bw vbox", false)
|
|
|
|
reposwin.Draw()
|
|
|
|
reposwin.Custom = func() {
|
|
|
|
log.Warn("GOT HERE: main() gadgets.NewBasicWindow() close")
|
|
|
|
log.Warn("Should I do something special here?")
|
|
|
|
}
|
|
|
|
|
2024-01-30 23:38:46 -06:00
|
|
|
repoAllButtons(reposbox)
|
|
|
|
|
2024-01-30 13:32:04 -06:00
|
|
|
reposgroup = reposbox.NewGroup("go repositories (read from ~/.config/myrepolist)")
|
2024-01-31 08:47:08 -06:00
|
|
|
reposgrid = reposgroup.NewGrid("test", 8, 1)
|
2024-01-30 13:32:04 -06:00
|
|
|
|
|
|
|
reposgrid.NewLabel("") // path goes here
|
|
|
|
|
|
|
|
reposgrid.NewLabel("last tag").SetProgName("last tag")
|
|
|
|
|
|
|
|
reposgrid.NewLabel("master version")
|
|
|
|
reposgrid.NewLabel("devel version")
|
|
|
|
reposgrid.NewLabel("user version")
|
|
|
|
|
|
|
|
reposgrid.NewLabel("Status")
|
|
|
|
|
|
|
|
reposgrid.NewLabel("Current Version").SetProgName("Current Version")
|
|
|
|
|
|
|
|
reposgrid.NewLabel("Show()")
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
addRepo(reposgrid, path, mbranch, dbranch, ubranch)
|
|
|
|
}
|
|
|
|
|
2024-01-30 21:54:51 -06:00
|
|
|
// TODO: figure out why this borks everything
|
2024-01-30 18:50:00 -06:00
|
|
|
/*
|
2024-01-30 23:38:46 -06:00
|
|
|
for i, path := range repostatus.ListGitDirectories() {
|
|
|
|
// log.Info("addRepo()", i, path)
|
|
|
|
tmp := strings.TrimPrefix(path, me.goSrcPwd.String())
|
|
|
|
log.Info("addRepo()", i, tmp)
|
|
|
|
addRepo(reposgrid, tmp, "guimaster", "guidevel", usr.Username)
|
|
|
|
}
|
2024-01-30 18:50:00 -06:00
|
|
|
*/
|
2024-01-30 13:32:04 -06:00
|
|
|
|
2024-01-30 23:38:46 -06:00
|
|
|
reposwin.Toggle()
|
|
|
|
}
|
|
|
|
|
|
|
|
func repoAllButtons(box *gui.Node) {
|
|
|
|
// reposbox.SetExpand(false)
|
|
|
|
group1 := box.NewGroup("Run on all repos:")
|
|
|
|
grid1 := group1.NewGrid("test", 6, 1)
|
|
|
|
|
|
|
|
grid1.NewButton("merge all user to devel", func() {
|
2024-01-30 13:32:04 -06:00
|
|
|
reposwin.Disable()
|
2024-02-02 15:22:48 -06:00
|
|
|
if ! mergeAllUserToDevel() {
|
|
|
|
return
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|
|
|
|
reposwin.Enable()
|
|
|
|
})
|
|
|
|
|
2024-01-30 23:38:46 -06:00
|
|
|
grid1.NewButton("merge all devel to main", func() {
|
2024-01-30 13:32:04 -06:00
|
|
|
reposwin.Disable()
|
2024-02-02 15:22:48 -06:00
|
|
|
if ! mergeAllDevelToMain() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
reposwin.Enable()
|
|
|
|
})
|
|
|
|
|
|
|
|
grid1.NewButton("merge it all", func() {
|
|
|
|
reposwin.Disable()
|
|
|
|
if ! mergeAllUserToDevel() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if ! mergeAllDevelToMain() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
reposwin.Enable()
|
|
|
|
})
|
|
|
|
|
|
|
|
grid1.NewButton("status.Update() all", func() {
|
|
|
|
for _, repo := range me.allrepos {
|
|
|
|
repo.status.Update()
|
|
|
|
repo.newScan()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
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())
|
|
|
|
// repo.status.Update()
|
|
|
|
if repo.status.RunDevelMergeB() {
|
|
|
|
log.Warn("THINGS SEEM OK fullAutomation() returned true.")
|
|
|
|
} else {
|
|
|
|
log.Warn("THINGS FAILED fullAutomation() returned false")
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
repo.status.Update()
|
|
|
|
repo.newScan()
|
|
|
|
}
|
|
|
|
log.Warn("EVERYTHING WORKED")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func mergeAllUserToDevel() bool {
|
2024-01-30 13:32:04 -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
|
|
|
|
}
|
2024-02-02 15:22:48 -06:00
|
|
|
if repo.dirtyLabel.String() != "merge to devel" {
|
|
|
|
log.Info("skipping. not merge to devel", repo.String(), repo.dirtyLabel.String())
|
2024-01-30 13:32:04 -06:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.status.CheckDirty() {
|
|
|
|
log.Info("skipping dirty", repo.String(), repo.dirtyLabel.String())
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
log.Info("found", repo.String(), repo.dirtyLabel.String())
|
|
|
|
// repo.status.Update()
|
|
|
|
if repo.status.RunDevelMergeB() {
|
|
|
|
log.Warn("THINGS SEEM OK fullAutomation() returned true.")
|
|
|
|
} else {
|
|
|
|
log.Warn("THINGS FAILED fullAutomation() returned false")
|
2024-02-02 15:22:48 -06:00
|
|
|
return false
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|
|
|
|
repo.status.Update()
|
|
|
|
repo.newScan()
|
|
|
|
}
|
|
|
|
log.Warn("EVERYTHING WORKED")
|
2024-02-02 15:22:48 -06:00
|
|
|
return true
|
2024-01-30 13:32:04 -06:00
|
|
|
}
|