more button cleanups

Signed-off-by: Jeff Carr <jcarr@wit.com>
This commit is contained in:
Jeff Carr 2024-01-20 17:17:48 -06:00
parent d67ace479a
commit 5f382cd5e3
4 changed files with 131 additions and 136 deletions

View File

@ -3,12 +3,10 @@ package main
import ( import (
"os" "os"
"strings"
"go.wit.com/log" "go.wit.com/log"
"go.wit.com/gui" "go.wit.com/gui"
"go.wit.com/lib/debugger"
"go.wit.com/lib/gadgets" "go.wit.com/lib/gadgets"
"go.wit.com/lib/gui/repostatus" "go.wit.com/lib/gui/repostatus"
) )
@ -56,12 +54,9 @@ func quickCmd(fullpath string, cmd []string) bool {
} }
func globalBuildOptions(box *gui.Node) { func globalBuildOptions(box *gui.Node) {
var setCurrentBranch *gui.Node vbox := box.NewVerticalBox("DISPLAYVBOX")
group1 := box.NewGroup("Global Build Options") group1 := vbox.NewGroup("Global Build Options")
groupvbox := group1.NewBox("bw vbox", false) grid := group1.NewGrid("buildOptions", 2, 1)
// grouphbox := groupvbox.NewBox("bw hbox", true)
grid := groupvbox.NewGrid("buildOptions", 2, 1)
me.mainBranch = gadgets.NewBasicCombobox(grid, "default main branch") me.mainBranch = gadgets.NewBasicCombobox(grid, "default main branch")
me.mainBranch.AddText("guimain") me.mainBranch.AddText("guimain")
@ -78,17 +73,23 @@ func globalBuildOptions(box *gui.Node) {
// this lets you select your user branch, but, when you are happy // this lets you select your user branch, but, when you are happy
// you can merge everything into the devel branch and make sure it actually // you can merge everything into the devel branch and make sure it actually
// works. Then, when that is good, merge and version everything in master // works. Then, when that is good, merge and version everything in master
guiBranch := gadgets.NewBasicCombobox(grid, "Set Current Working Branch") var newBranch *gui.Node
guiBranch.AddText("guimaster") grid.NewButton("set all branches to", func() {
guiBranch.AddText("guidevel") log.Warn("set all branches to:", newBranch.String())
guiBranch.AddText("jcarr") /*
guiBranch.Custom = func() { me.toMoveToBranch = guiBranch.String()
me.toMoveToBranch = guiBranch.String() setCurrentBranch.SetLabel("set all branches to " + me.toMoveToBranch)
setCurrentBranch.SetLabel("set all branches to " + me.toMoveToBranch) me.mainBranch.Disable()
me.mainBranch.Disable() */
} })
newBranch = grid.NewCombobox()
newBranch.AddText("guimaster")
newBranch.AddText("guidevel")
newBranch.AddText("jcarr")
newBranch.SetText("jcarr")
groupvbox.NewButton("git status", func() { group2 := vbox.NewGroup("Run in every git repository")
group2.NewButton("git status", func() {
quickCmdDoNotRun = false quickCmdDoNotRun = false
quickCmdLastPath = "~/go/src" quickCmdLastPath = "~/go/src"
quickCmds = [][]string{} quickCmds = [][]string{}
@ -99,105 +100,17 @@ func globalBuildOptions(box *gui.Node) {
} }
}) })
groupvbox.NewButton("rebuild autotypist", func() { me.rerunGoMod = group2.NewButton("remove go.mod & go.sum", func() {
os.Setenv("GO111MODULE", "off") log.Info("TODO: remove them")
quickCmdDoNotRun = true
quickCmdLastPath = "~/go/src"
quickCmds = [][]string{}
log.Warn("scanning allrepos")
fullpath := "/home/jcarr/"
quickCmd(fullpath, []string{"mkdir", "-p", "/home/jcarr/go/src/go.wit.com/apps/"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/"
quickCmd(fullpath, []string{"go", "get", "go.wit.com/apps/autotypist"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/autotypist"
quickCmd(fullpath, []string{"go", "get", "-v", "go.wit.com/toolkits/debian"})
fullpath = "/home/jcarr/go/src/go.wit.com/toolkits/debian"
quickCmd(fullpath, []string{"make", "download"})
quickCmd(fullpath, []string{"make"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/autotypist"
quickCmd(fullpath, []string{"go", "get", "-v", "-u", "."})
quickCmd(fullpath, []string{"go", "build", "-v", "-x"})
me.script = quickCmds
setGitCommands()
}) })
me.rerunGoMod = groupvbox.NewButton("remove all go.mod and go.sum", func() { me.rerunGoMod = group2.NewButton("run go mod & go tidy", func() {
quickCmdDoNotRun = false
log.Warn("scanning allrepos")
for _, path := range me.allrepos {
fullpath := "/home/jcarr/go/src/" + path
quickCmd(fullpath, []string{"rm", "-f", "go.mod", "go.sum"})
}
})
me.rerunGoMod = groupvbox.NewButton("re-run go mod & go tidy", func() {
quickCmdDoNotRun = false quickCmdDoNotRun = false
os.Unsetenv("GO111MODULE") os.Unsetenv("GO111MODULE")
log.Warn("scanning allrepos")
for _, path := range me.allrepos { for _, path := range me.allrepos {
fullpath := "/home/jcarr/go/src/" + path fullpath := "/home/jcarr/go/src/" + path
quickCmd(fullpath, []string{"go", "mod", "init"}) quickCmd(fullpath, []string{"go", "mod", "init"})
quickCmd(fullpath, []string{"go", "mod", "tidy"}) quickCmd(fullpath, []string{"go", "mod", "tidy"})
} }
}) })
setCurrentBranch = groupvbox.NewButton("set all branches to", func() {
log.Warn("scanning allrepos")
for repo, path := range me.allrepos {
log.Warn("found repo", repo.String())
var changeBranch [][]string
changeBranch = append(changeBranch, []string{"cd", "go/src/" + path})
changeBranch = append(changeBranch, []string{"git", "checkout", me.toMoveToBranch})
me.script = changeBranch
setGitCommands()
// goMake("--doit")
}
})
var everything *gui.Node
everything = groupvbox.NewButton("go get everything on go.wit.com", func() {
quickCmdDoNotRun = false
quickCmds = [][]string{}
var perfect bool = true
repos := myrepolist()
for _, line := range repos {
log.Warn("repo =", line)
path, _, _, _ := splitLine(line)
path = strings.TrimSpace(path)
if path == "#" {
// skip comment lines
continue
}
if doesExist("/home/jcarr/go/src/" + path) {
continue
}
// attempt to download it
quickCmd("/home/jcarr/go/src/go.wit.com", []string{"go", "get", "-v", path})
perfect = false
}
if perfect {
var notes [][]string
notes = append(notes, []string{"you have already downloaded"})
notes = append(notes, []string{"everything on go.wit.com"})
me.script = notes
setGitCommands()
doit.Disable()
everything.Disable()
return
}
me.script = quickCmds
doit.Enable()
setGitCommands()
})
groupvbox.NewButton("build all apps", func() {
listWindow()
})
groupvbox.NewButton("Debugger", func() {
debugger.DebugWindow()
})
} }

View File

@ -3,31 +3,33 @@ package main
import ( import (
"go.wit.com/gui" "go.wit.com/gui"
"go.wit.com/lib/debugger"
"go.wit.com/lib/gui/logsettings" "go.wit.com/lib/gui/logsettings"
// "go.wit.com/gui/gadgets" // "go.wit.com/gui/gadgets"
) )
func globalDisplayOptions(box *gui.Node) { func globalDisplayOptions(box *gui.Node) {
group1 := box.NewGroup("Global Display Options") vbox := box.NewVerticalBox("DISPLAYVBOX")
groupvbox := group1.NewBox("bw vbox", false)
groupvbox.NewButton("Show Repository Window", func() { group1 := vbox.NewGroup("Global Display Options")
group1.NewButton("Show Repository Window", func() {
reposwin.Toggle() reposwin.Toggle()
}) })
/* /*
groupvbox.NewButton("hide all", func() { group1.NewButton("hide all", func() {
for repo, _ := range me.allrepos { for repo, _ := range me.allrepos {
repo.Hide() repo.Hide()
} }
}) })
groupvbox.NewButton("show all", func() { group1.NewButton("show all", func() {
for repo, _ := range me.allrepos { for repo, _ := range me.allrepos {
repo.Show() repo.Show()
} }
}) })
*/ */
me.autoHidePerfect = groupvbox.NewCheckbox("Hide Perfectly clean repos").SetChecked(true) me.autoHidePerfect = group1.NewCheckbox("Hide Perfectly clean repos").SetChecked(true)
me.autoHidePerfect.Custom = func() { me.autoHidePerfect.Custom = func() {
if me.autoHidePerfect.Checked() { if me.autoHidePerfect.Checked() {
for repo, _ := range me.allrepos { for repo, _ := range me.allrepos {
@ -42,21 +44,26 @@ func globalDisplayOptions(box *gui.Node) {
} }
} }
groupvbox.NewButton("status.Update() all", func() { group1.NewButton("status.Update() all", func() {
for repo, _ := range me.allrepos { for repo, _ := range me.allrepos {
repo.status.Update() repo.status.Update()
} }
}) })
groupvbox.NewButton("rescan all", func() { group1.NewButton("rescan all", func() {
for repo, _ := range me.allrepos { for repo, _ := range me.allrepos {
repo.newScan() repo.newScan()
} }
}) })
groupvbox.NewButton("logging enable/disable", func() { group2 := vbox.NewGroup("Debugger")
group2.NewButton("logging Window", func() {
logsettings.LogWindow() logsettings.LogWindow()
}) })
group2.NewButton("Debugger Window", func() {
debugger.DebugWindow()
})
} }
func hidePerfect() { func hidePerfect() {

80
globalTestingOptions.go Normal file
View File

@ -0,0 +1,80 @@
package main
import (
"os"
"strings"
"go.wit.com/log"
"go.wit.com/gui"
)
// things being testing
func globalTestingOptions(box *gui.Node) {
test1 := box.NewGroup("testing build")
test1.NewButton("rebuild autotypist", func() {
os.Setenv("GO111MODULE", "off")
quickCmdDoNotRun = true
quickCmdLastPath = "~/go/src"
quickCmds = [][]string{}
log.Warn("scanning allrepos")
fullpath := "/home/jcarr/"
quickCmd(fullpath, []string{"mkdir", "-p", "/home/jcarr/go/src/go.wit.com/apps/"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/"
quickCmd(fullpath, []string{"go", "get", "go.wit.com/apps/autotypist"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/autotypist"
quickCmd(fullpath, []string{"go", "get", "-v", "go.wit.com/toolkits/debian"})
fullpath = "/home/jcarr/go/src/go.wit.com/toolkits/debian"
quickCmd(fullpath, []string{"make", "download"})
quickCmd(fullpath, []string{"make"})
fullpath = "/home/jcarr/go/src/go.wit.com/apps/autotypist"
quickCmd(fullpath, []string{"go", "get", "-v", "-u", "."})
quickCmd(fullpath, []string{"go", "build", "-v", "-x"})
me.script = quickCmds
setGitCommands()
})
var everything *gui.Node
everything = test1.NewButton("go get everything on go.wit.com", func() {
quickCmdDoNotRun = false
quickCmds = [][]string{}
var perfect bool = true
repos := myrepolist()
for _, line := range repos {
log.Warn("repo =", line)
path, _, _, _ := splitLine(line)
path = strings.TrimSpace(path)
if path == "#" {
// skip comment lines
continue
}
if doesExist("/home/jcarr/go/src/" + path) {
continue
}
// attempt to download it
quickCmd("/home/jcarr/go/src/go.wit.com", []string{"go", "get", "-v", path})
perfect = false
}
if perfect {
var notes [][]string
notes = append(notes, []string{"you have already downloaded"})
notes = append(notes, []string{"everything on go.wit.com"})
me.script = notes
setGitCommands()
doit.Disable()
everything.Disable()
return
}
me.script = quickCmds
doit.Enable()
setGitCommands()
})
test1.NewButton("build all apps", func() {
listWindow()
})
}

15
main.go
View File

@ -26,8 +26,9 @@ func main() {
autotypistWindow() autotypistWindow()
repoworld() repoworld()
log.Sleep(.3)
// hidePerfect() // keeps the app alive
// TODO: rescan the status of the repos every so often?
gui.Watchdog() gui.Watchdog()
} }
@ -78,18 +79,12 @@ func addRepo(grid *gui.Node, path string, master string, devel string, user stri
} }
func autotypistWindow() { func autotypistWindow() {
/*
me.autotypistWindow = gadgets.NewBasicWindow(me.myGui, "autotypist for GO & git. it types faster than you can.")
me.autotypistWindow.Make()
me.autotypistWindow.StandardExit()
box := me.autotypistWindow.Box()
me.autotypistWindow.Draw()
*/
win := me.myGui.NewWindow("autotypist for GO & git. it types faster than you can.") win := me.myGui.NewWindow("autotypist for GO & git. it types faster than you can.")
box := win.NewBox("bw hbox", true) box := win.NewBox("bw hbox", true)
globalDisplayOptions(box) globalDisplayOptions(box)
globalBuildOptions(box) globalBuildOptions(box)
globalTestingOptions(box)
globalResetOptions(box) globalResetOptions(box)
} }