// This is a simple example package main import ( "fmt" "os" "path/filepath" "strconv" "strings" "go.wit.com/gui" "go.wit.com/lib/gadgets" "go.wit.com/lib/gui/repostatus" "go.wit.com/lib/gui/shell" "go.wit.com/log" // "go.wit.com/gui/gadgets" ) type develSummary struct { grid *gui.Node updateB *gui.Node docsB *gui.Node totalOL *gadgets.OneLiner dirtyOL *gadgets.OneLiner readonlyOL *gadgets.OneLiner totalPatchesOL *gadgets.OneLiner allp []*patch } func summaryBox(box *gui.Node) *develSummary { s := new(develSummary) group1 := box.NewGroup("Development Branch Summary") s.grid = group1.RawGrid() s.updateB = s.grid.NewButton("Update Stats", func() { // globalDisplaySetRepoState() // reposwin.Toggle() s.Update() }) s.updateB = s.grid.NewButton("List Patches", func() { for i, p := range s.allp { log.Info(i, p.ref, p.rs.String()) } }) s.docsB = s.grid.NewButton("open docs (localhost:8080)", func() { me.autotypistWindow.Disable() defer me.autotypistWindow.Enable() goSrcDir := me.goSrcPwd.String() filename := filepath.Join(goSrcDir, "go.work") f, err := os.OpenFile(filename, os.O_WRONLY|os.O_CREATE, 0600) if err != nil { return } defer f.Close() fmt.Fprintln(f, "go 1.21.4") fmt.Fprintln(f, "") fmt.Fprintln(f, "use (") for _, repo := range me.allrepos { if repo.status.Exists("go.mod") { fmt.Fprintln(f, "\t"+repo.String()) } else { log.Info("missing go.mod for", repo.String()) repo.status.MakeRedomod() } } fmt.Fprintln(f, ")") tmp := me.userHomePwd.String() tmpDir := filepath.Join(tmp, "go/src") os.Chdir(tmpDir) pkgsite := filepath.Join(tmp, "go/bin", "pkgsite") os.Unsetenv("GO111MODULE") go shell.Run([]string{pkgsite}) shell.Run([]string{"ping", "-c", "3", "git.wit.org"}) shell.OpenBrowser("http://localhost:8080") }) s.grid.NextRow() s.totalOL = gadgets.NewOneLiner(s.grid, "Total") s.grid.NextRow() s.dirtyOL = gadgets.NewOneLiner(s.grid, "dirty") s.grid.NextRow() s.readonlyOL = gadgets.NewOneLiner(s.grid, "read-only") s.grid.NextRow() s.totalPatchesOL = gadgets.NewOneLiner(s.grid, "total commits") s.grid.NextRow() return s } func (s *develSummary) Update() { var total, dirty, readonly int for _, repo := range me.allrepos { total += 1 if repo.status.CheckDirty() { dirty += 1 } if repo.status.ReadOnly() { readonly += 1 } } s.totalOL.SetText(strconv.Itoa(total) + " repos") s.dirtyOL.SetText(strconv.Itoa(dirty) + " repos") s.readonlyOL.SetText(strconv.Itoa(readonly) + " repos") p, allp := s.GetPatches() if s.allp == nil { s.allp = make([]*patch, 0, 0) s.allp = append(s.allp, allp...) } s.totalPatchesOL.SetText(strconv.Itoa(p) + " patches") } type patch struct { ref string comment string rs *repostatus.RepoStatus } func (s *develSummary) GetPatches() (int, []*patch) { var patchcount int patches := make([]*patch, 0, 0) for _, repo := range me.allrepos { // git log --oneline devel..jcarr userv := repo.status.GetUserVersion() develv := repo.status.GetDevelVersion() usern := repo.status.GetUserBranchName() develn := repo.status.GetDevelBranchName() if userv == develv { // log.Info("skipping unchanged repo", repo.String()) } else { // log.Info("repo userv, develv", userv, develv) gitcmd := []string{"git", "log", "--oneline", develn + ".." + usern} // log.Info("Run:", gitcmd) err, output := repo.status.RunCmd(gitcmd) if err == nil { // patches := strings.Split(output, "\n") for _, line := range strings.Split(output, "\n") { parts := strings.Split(line, " ") newp := new(patch) newp.rs = repo.status newp.ref = parts[0] newp.comment = strings.Join(parts[1:], " ") log.Info("patch:", line, newp.rs.String()) patchcount += 1 patches = append(patches, newp) } } else { log.Info("git failed err=", err) } } } return patchcount, patches }