// This is a simple example package main import ( "fmt" "os" "path/filepath" "strings" "time" "go.wit.com/gui" "go.wit.com/log" "go.wit.com/lib/gadgets" "go.wit.com/lib/gui/repolist" "go.wit.com/lib/gui/shell" ) type releaseStruct struct { box *gui.Node group *gui.Node grid *gui.Node repo *gadgets.OneLiner status *gadgets.OneLiner readOnly *gadgets.OneLiner notes *gadgets.OneLiner version *gadgets.OneLiner releaseVersionB *gui.Node reason *gadgets.BasicEntry openrepo *gui.Node goGetB *gui.Node checkGoSumB *gui.Node checkDirtyB *gui.Node makeRedomodB *gui.Node sendVersionB *gui.Node checkSafeB *gui.Node whitelist map[string]*repolist.RepoRow // store myself here. use myself to // do garbage go get tests and other potential junk guireleaser *repolist.RepoRow } func (w *autoType) Disable() { me.mainBox.Disable() } func (w *autoType) Enable() { me.mainBox.Enable() } func createReleaseBox(box *gui.Node) { me.release.box = box.NewVerticalBox("vbox") me.release.group = me.release.box.NewGroup("Current Repo") me.release.grid = me.release.group.NewGrid("buildOptions", 0, 0) me.release.grid.NextRow() me.release.releaseVersionB = me.release.grid.NewButton("release version", func() { buttonDisable() if doRelease() { buttonEnable() log.Info("doRelease() worked") } else { log.Info("doRelease() failed") } }) me.release.grid.NewButton("Find Next Releasable", func() { me.Disable() defer me.Enable() if findNext() { log.Info("findNext() found a repo") return } }) me.release.grid.NextRow() me.release.repo = gadgets.NewOneLiner(me.release.grid, "repo") me.release.openrepo = me.release.grid.NewButton("Configure", func() { me.current.Status.Toggle() }) me.release.openrepo.Disable() me.release.grid.NextRow() me.release.status = gadgets.NewOneLiner(me.release.grid, "status") me.release.grid.NextRow() me.release.readOnly = gadgets.NewOneLiner(me.release.grid, "read-only") me.release.grid.NextRow() me.release.notes = gadgets.NewOneLiner(me.release.grid, "notes") me.release.grid.NextRow() me.release.version = gadgets.NewOneLiner(me.release.grid, "version") me.release.grid.NextRow() me.release.reason = gadgets.NewBasicEntry(me.release.grid, "release reason") me.release.reason.SetText(me.releaseReasonS) me.release.grid.NextRow() me.autoWorkingPwd = gadgets.NewOneLiner(me.release.grid, "working directory (pwd)") me.release.grid.NextRow() me.userHomePwd = gadgets.NewOneLiner(me.release.grid, "user home") me.release.grid.NextRow() me.goSrcPwd = gadgets.NewOneLiner(me.release.grid, "go src home") me.release.grid.NextRow() homeDir, err := os.UserHomeDir() if err != nil { log.Warn("Error getting home directory:", err) homeDir = "/home/autotypist" } me.userHomePwd.SetText(homeDir) srcDir := filepath.Join(homeDir, "go/src") me.goSrcPwd.SetText(srcDir) testf := filepath.Join(srcDir, "go.wit.com/apps/guireleaser", "go.sum") if !shell.Exists(testf) { pb := me.forge.Repos.FindByGoPath("go.wit.com/apps/guireleaser") if pb != nil { pb.RedoGoMod() } if !shell.Exists(testf) { log.Info("go.sum missing", testf) panic("redo go.sum") } } group := me.release.box.NewGroup("Run on Current Repo") grid := group.NewGrid("buildOptions", 0, 0) grid.NewButton("whitelist", func() { // tmp := me.current.GoState() log.Info("trying to whitelist repo", me.current.GoPath()) me.current.Status.Whitelist = true findNext() }) grid.NextRow() group = me.release.box.NewGroup("Process against all repos") grid = group.NewGrid("buildOptions", 0, 0) grid.NewButton("doRelease() all", func() { buttonDisable() // rather than loop forever, at least limit this to the number of repos // incase something, somewhere, goes wrong ok, duration := doReleaseAll() s := fmt.Sprint(duration) log.Info("release returned", ok, "and ran for", s, "findCounter =", findCounter) if findCounter != 0 { log.Info("should try thsi doRelease() loop again since findCounter =", findCounter) } buttonEnable() }) grid.NextRow() group = me.release.box.NewGroup("experimental and potentially dangerous stuff") grid = group.NewGrid("buildOptions", 0, 0) me.setBranchesToMasterB = grid.NewButton("set all branches to master", func() { me.Disable() defer me.Enable() if setAllBranchesToMaster() { // if it succeeds, disable this button me.setBranchesToMasterB.Disable() } }) grid.NextRow() grid.NewButton("git ls-files |grep go.mod", func() { loop := me.repos.View.ReposSortByName() for loop.Scan() { repo := loop.Repo() log.Info("repo:", repo.Name()) if repo.Status.ReadOnly() { continue } if repo.Status.Whitelist { log.Warn("skipping whitelist", repo.GoPath()) continue } good, files := repo.Status.GitLsFiles() if !good { 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?") 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?") 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") }) grid.NextRow() } func doReleaseAll() (bool, time.Duration) { var worked bool = true findCounter = 0 duration := repolist.TimeFunction(func() { loop := me.repos.View.ReposSortByName() for loop.Scan() { loop.Repo() if doRelease() { log.Info("doRelease() worked. findCounter =", findCounter) } else { if os.Getenv("FindNextDone") == "true" { log.Info("findNext says it was done. findCounter =", findCounter) log.Info("findNext says it was done. findCounter =", findCounter) log.Info("we can os.Exit here") } if me.release.status.String() == "ALL DONE?" { log.Info("maybe ALL DONE?. findCounter =", findCounter) buttonEnable() worked = true // os.Exit(0) } log.Info("doRelease() failed. findCounter =", findCounter) worked = false break } } }) return worked, duration } func buttonDisable() { me.Disable() me.release.box.Disable() } func buttonEnable() { me.Enable() me.release.box.Enable() }