guireleaser/globalDisplayOptions.go

314 lines
7.3 KiB
Go
Raw Normal View History

package main
import (
"os"
"strings"
"go.wit.com/gui"
"go.wit.com/lib/debugger"
"go.wit.com/lib/gui/logsettings"
2024-02-19 22:00:58 -06:00
"go.wit.com/lib/gui/repolist"
"go.wit.com/log"
)
2024-02-19 22:00:58 -06:00
func showHideRepos(repo *repolist.Repo) {
// always show dirty repos
if repo.IsDirty() {
repo.Show()
return
}
// always show repos that have not been merged to main
if repo.GoState() == "merge to devel" {
repo.Show()
return
}
2024-02-19 14:40:21 -06:00
2024-02-19 22:00:58 -06:00
// hide read-only repos. These are repos that do not
// match things in the users config file (.config/autotypist)
if me.autoHideReadOnly.Checked() {
if repo.Status.ReadOnly() {
repo.Hide()
return
}
2024-02-19 22:00:58 -06:00
}
if me.autoHidePerfect.Checked() {
if repo.State() == "PERFECT" {
repo.Hide()
return
}
2024-02-19 22:00:58 -06:00
}
if me.autoReleased.Checked() {
if repo.GoState() == "RELEASED" {
repo.Hide()
return
}
}
2024-02-19 22:00:58 -06:00
repo.Show()
}
func globalDisplayShow() {
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if me.autoHideReadOnly.Checked() {
2024-02-18 15:09:04 -06:00
if repo.Status.ReadOnly() {
continue
}
}
if me.autoHidePerfect.Checked() {
2024-02-18 15:09:04 -06:00
if repo.State() == "PERFECT" {
continue
}
}
repo.Show()
}
}
func globalDisplayOptions(box *gui.Node) {
vbox := box.NewVerticalBox("DISPLAYVBOX")
group1 := vbox.NewGroup("Global Display Options")
2024-02-19 19:42:14 -06:00
hidegrid := group1.NewGrid("hidecfg", 0, 0)
hidegrid.NewButton("Show Repository Window", func() {
2024-02-18 15:09:04 -06:00
if me.repos.Hidden() {
me.repos.Show()
} else {
2024-02-18 15:09:04 -06:00
me.repos.Hide()
}
2024-02-18 15:09:04 -06:00
log.Info("showing reposwin")
2024-02-19 22:00:58 -06:00
// showHideRepos()
2024-02-18 15:09:04 -06:00
// have to run this twice for now
// scanForReady()
// scanForReady()
// findNextDirty("")
// double check the found next repo
// fullDoubleCheckFix()
})
2024-02-19 19:42:14 -06:00
hidegrid.NextRow()
2024-02-19 19:42:14 -06:00
me.autoHideReadOnly = hidegrid.NewCheckbox("Hide read-only repos").SetChecked(true)
me.autoHideReadOnly.Custom = func() {
if me.autoHideReadOnly.Checked() {
2024-02-19 22:00:58 -06:00
// showHideRepos()
} else {
globalDisplayShow()
}
}
2024-02-19 19:42:14 -06:00
hidegrid.NextRow()
2024-02-19 19:42:14 -06:00
me.autoHidePerfect = hidegrid.NewCheckbox("Hide Perfectly clean repos").SetChecked(true)
me.autoHidePerfect.Custom = func() {
2024-02-19 22:00:58 -06:00
log.Info("registered hide function to showHideRepos()")
me.repos.View.RegisterHideFunction(showHideRepos)
/*
if me.autoHidePerfect.Checked() {
showHideRepos()
} else {
globalDisplayShow()
}
*/
}
2024-02-19 19:42:14 -06:00
hidegrid.NextRow()
2024-02-19 19:42:14 -06:00
me.autoReleased = hidegrid.NewCheckbox("Hide RELEASED repos").SetChecked(false)
me.autoReleased.Custom = func() {
if me.autoReleased.Checked() {
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
2024-02-18 17:55:59 -06:00
if repo.GoState() == "RELEASED" {
repo.Hide()
}
}
} else {
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
repo.Show()
}
}
}
2024-02-19 19:42:14 -06:00
hidegrid.NextRow()
me.ignoreWhitelist = hidegrid.NewCheckbox("ignore whitelist (are you sure?)").SetChecked(false)
hidegrid.NextRow()
2024-02-19 19:42:14 -06:00
me.scanEveryMinute = hidegrid.NewCheckbox("Scan every minute").SetChecked(false)
hidegrid.NewButton("scan now", func() {
log.Info("re-scanning repos now")
i, s := me.repos.View.ScanRepositories()
log.Info("re-scanning repos done", i, s)
me.duration.SetText(s)
})
me.duration = hidegrid.NewLabel("")
hidegrid.NextRow()
2024-02-19 19:42:14 -06:00
grid := group1.NewGrid("test", 0, 0)
2024-02-19 19:42:14 -06:00
grid.NewButton("git checkout master", func() {
setBranchToMaster()
})
2024-02-19 22:00:58 -06:00
grid.NewButton("find first repo", func() {
// set the target versions
setTargetVersion()
// have to run this twice for now. not sure why
scanForReady()
scanForReady()
findNextDirty("")
// double check the found next repo
fullDoubleCheckFix()
})
2024-02-19 19:42:14 -06:00
me.setBranchesToMasterB = grid.NewButton("set all branches to master", func() {
me.Disable()
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if repo.Status.ReadOnly() {
continue
}
2024-02-18 15:09:04 -06:00
if whitelist(repo.GoPath()) {
continue
}
2024-02-18 15:09:04 -06:00
if repo.Status.CheckoutMaster() {
log.Warn("set master branch worked", repo.Name())
repo.Status.UpdateNew()
} else {
2024-02-18 15:09:04 -06:00
repo.Status.UpdateNew()
log.Warn("set master branch failed", repo.Name())
log.Warn("set master branch failed", repo.Name())
log.Warn("set master branch failed", repo.Name())
}
}
me.Enable()
me.setBranchesToMasterB.Disable()
})
var longB *gui.Node
2024-02-19 19:42:14 -06:00
longB = grid.NewButton("redo go.sum", func() {
os.Unsetenv("GO111MODULE")
longB.Disable()
me.Disable()
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if whitelist(repo.GoPath()) {
continue
}
2024-02-18 15:09:04 -06:00
if repo.Status.ReadOnly() {
continue
}
2024-02-18 15:09:04 -06:00
if repo.Status.MakeRedomod() {
log.Info("redo go.sum failed on", repo.Name())
// me.Enable()
// longB.Enable()
// longB.SetLabel("FAILED")
// return
}
}
log.Info("redo go.sum finished ok!")
longB.Disable()
me.Enable()
longB.Enable()
})
2024-02-19 19:42:14 -06:00
grid.NewButton("set target version", func() {
setTargetVersion()
})
grid.NextRow()
grid.NewButton("rm -f go.mod go.sum", func() {
me.Disable()
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if whitelist(repo.GoPath()) {
continue
}
2024-02-18 15:09:04 -06:00
if repo.Status.ReadOnly() {
continue
}
2024-02-18 15:09:04 -06:00
repo.Status.RunCmd([]string{"rm", "-f", "go.mod", "go.sum"})
}
me.Enable()
})
2024-02-19 19:42:14 -06:00
grid.NewButton("git reset --hard", func() {
me.Disable()
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if whitelist(repo.GoPath()) {
log.Warn("skipping whitelist", repo.Name())
continue
}
2024-02-18 15:09:04 -06:00
log.Warn("running git reset --hard", repo.Name())
repo.Status.RunCmd([]string{"git", "reset", "--hard"})
}
me.Enable()
})
2024-02-19 19:42:14 -06:00
grid.NewButton("git ls-files |grep go.mod", func() {
// var all []string
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
log.Info("repo:", repo.Name())
if repo.Status.ReadOnly() {
continue
}
2024-02-18 15:09:04 -06:00
if whitelist(repo.GoPath()) {
log.Warn("skipping whitelist", repo.GoPath())
continue
}
2024-02-18 15:09:04 -06:00
good, files := repo.Status.GitLsFiles()
if !good {
2024-02-18 15:09:04 -06:00
log.Warn("Something went wrong", repo.GoPath())
continue
}
for _, filename := range strings.Split(files, "\n") {
log.Info("\tfile", filename)
if filename == "go.mod" {
log.Info("Found go.mod. does version match release version?")
2024-02-18 15:09:04 -06:00
log.Info(repo.Status.GetLastTagVersion(), "vs", repo.Status.GetTargetVersion())
if repo.Status.GetLastTagVersion() != repo.Status.GetTargetVersion() {
log.Info(repo.Status.GetLastTagVersion(), "vs", repo.Status.GetTargetVersion())
log.Info("Found go.sum. version mismatch")
setCurrentRepo(repo, "VERY BROKEN", "rewind go.mod commit")
return
}
}
if filename == "go.sum" {
log.Info("Found go.sum. does version match release version?")
2024-02-18 15:09:04 -06:00
log.Info(repo.Status.GetLastTagVersion(), "vs", repo.Status.GetTargetVersion())
if repo.Status.GetLastTagVersion() != repo.Status.GetTargetVersion() {
log.Info(repo.Status.GetLastTagVersion(), "vs", repo.Status.GetTargetVersion())
log.Info("Found go.sum. version mismatch")
setCurrentRepo(repo, "VERY BROKEN", "rewind go.mod commit")
return
}
}
}
}
log.Info("All repos seem okay")
})
2024-02-19 19:42:14 -06:00
grid.NextRow()
2024-02-19 19:42:14 -06:00
grid.NewButton("scanForReady()", func() {
2024-02-18 17:55:59 -06:00
scanForReady()
})
group2 := vbox.NewGroup("Debugger")
2024-02-19 19:42:14 -06:00
dbggrid := group2.NewGrid("gdb", 0, 0)
dbggrid.NewButton("logging Window", func() {
logsettings.LogWindow()
})
2024-02-19 19:42:14 -06:00
dbggrid.NextRow()
2024-02-19 19:42:14 -06:00
dbggrid.NewButton("Debugger Window", func() {
debugger.DebugWindow()
})
}
func hidePerfect() {
2024-02-18 15:09:04 -06:00
for _, repo := range me.repos.View.AllRepos() {
if repo.State() == "PERFECT" {
if repo.Hidden() {
continue
}
repo.Hide()
// return
}
}
}