2024-01-09 01:16:00 -06:00
|
|
|
package main
|
|
|
|
|
2024-01-18 00:58:14 -06:00
|
|
|
import (
|
2024-11-07 03:10:21 -06:00
|
|
|
"embed"
|
2024-02-14 01:04:31 -06:00
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2024-12-13 20:32:07 -06:00
|
|
|
"strings"
|
2024-01-09 10:21:58 -06:00
|
|
|
|
2024-04-15 05:05:27 -05:00
|
|
|
"go.wit.com/dev/alexflint/arg"
|
2024-01-18 05:03:04 -06:00
|
|
|
"go.wit.com/gui"
|
2024-02-14 01:04:31 -06:00
|
|
|
"go.wit.com/lib/gui/shell"
|
2024-11-29 22:21:58 -06:00
|
|
|
"go.wit.com/lib/protobuf/forgepb"
|
2024-02-09 11:50:16 -06:00
|
|
|
"go.wit.com/log"
|
2024-01-09 01:16:00 -06:00
|
|
|
)
|
|
|
|
|
2024-02-28 22:01:32 -06:00
|
|
|
var VERSION string
|
2024-11-07 03:10:21 -06:00
|
|
|
|
|
|
|
//go:embed resources/*
|
|
|
|
var resources embed.FS
|
|
|
|
|
2024-12-02 08:45:13 -06:00
|
|
|
var argv args
|
2024-02-28 22:01:32 -06:00
|
|
|
|
2024-01-09 01:16:00 -06:00
|
|
|
func main() {
|
2024-01-23 11:22:33 -06:00
|
|
|
me = new(autoType)
|
2024-01-18 05:03:04 -06:00
|
|
|
|
2024-11-22 08:41:37 -06:00
|
|
|
// load the ~/.config/forge/ config
|
2024-11-29 22:21:58 -06:00
|
|
|
me.forge = forgepb.Init()
|
2024-12-01 10:42:49 -06:00
|
|
|
// me.forge.ConfigPrintTable()
|
2024-11-29 22:21:58 -06:00
|
|
|
os.Setenv("REPO_WORK_PATH", me.forge.GetGoSrc())
|
2024-11-22 08:41:37 -06:00
|
|
|
|
2024-03-09 22:02:32 -06:00
|
|
|
// parse the command line
|
2024-12-02 08:45:13 -06:00
|
|
|
arg.MustParse(&argv)
|
2024-03-09 22:02:32 -06:00
|
|
|
|
2024-03-02 20:47:10 -06:00
|
|
|
// save the ENV var here
|
|
|
|
me.releaseReasonS = os.Getenv("GUIRELEASE_REASON")
|
2024-02-14 01:04:31 -06:00
|
|
|
|
2024-03-02 20:47:10 -06:00
|
|
|
if me.releaseReasonS == "" {
|
2024-11-07 01:39:26 -06:00
|
|
|
log.Info("shell ENV GUIRELEASE_REASON not set")
|
2024-02-14 01:04:31 -06:00
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
2024-02-20 06:53:07 -06:00
|
|
|
// unset the go development ENV var to generate release files
|
|
|
|
// this is required for go mod init & tidy. Also, if the
|
|
|
|
// user drops to a shell or xterm, then they shouldn't be set there either
|
|
|
|
os.Unsetenv("GO111MODULE")
|
|
|
|
|
2024-01-18 05:03:04 -06:00
|
|
|
me.myGui = gui.New()
|
2024-11-07 03:10:21 -06:00
|
|
|
me.myGui.InitEmbed(resources)
|
2024-01-18 05:03:04 -06:00
|
|
|
me.myGui.Default()
|
2024-01-09 01:16:00 -06:00
|
|
|
|
2024-02-18 15:09:04 -06:00
|
|
|
// our main window
|
2024-02-28 22:01:32 -06:00
|
|
|
me.mainWindow = me.myGui.NewWindow("GUI release manager " + VERSION)
|
2024-01-30 14:05:22 -06:00
|
|
|
me.mainBox = me.mainWindow.NewBox("bw hbox", true)
|
|
|
|
|
2024-11-04 08:16:42 -06:00
|
|
|
// start the http server for polling status
|
|
|
|
go startHTTP()
|
|
|
|
|
2024-02-18 15:09:04 -06:00
|
|
|
// sanity check of things that might be around that mess
|
|
|
|
// up things later
|
2024-02-14 01:04:31 -06:00
|
|
|
// if you have a go.work file, you must delete it
|
|
|
|
// TODO: check for go.work files anywhere
|
|
|
|
homeDir, _ := os.UserHomeDir()
|
|
|
|
gowork := filepath.Join(homeDir, "go/src/go.work")
|
|
|
|
if shell.Exists(gowork) {
|
|
|
|
log.Info("go.work must be deleted")
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
|
2024-02-18 17:55:59 -06:00
|
|
|
log.Info("Creating the Release Window")
|
|
|
|
|
2024-02-20 14:44:38 -06:00
|
|
|
// initialize the repo list window
|
|
|
|
// which should be all the git repositories in ~/go/src & the .config file
|
2024-02-18 15:09:04 -06:00
|
|
|
me.repos = makeRepoView()
|
2024-02-18 17:55:59 -06:00
|
|
|
|
2024-02-20 14:44:38 -06:00
|
|
|
// the left side of the window options
|
|
|
|
globalDisplayOptions(me.mainBox)
|
|
|
|
|
2024-02-18 17:55:59 -06:00
|
|
|
// create the right side of the main window
|
|
|
|
createReleaseBox(me.mainBox)
|
|
|
|
|
|
|
|
// disable the open repo button. this isn't really important
|
|
|
|
// but does indicates the app (and toolkit) is working
|
|
|
|
// this can be removed later, but in these early days, I'm using this
|
|
|
|
// tool to release the code for this app, the gui and the gui toolkits
|
|
|
|
// and sometimes they lie, don't display stuff, don't even disable things
|
|
|
|
// so I can't trust even what I see. It's complicated right now still.
|
2024-02-20 16:11:00 -06:00
|
|
|
me.release.openrepo.Disable()
|
2024-02-18 17:55:59 -06:00
|
|
|
|
2024-11-13 18:32:53 -06:00
|
|
|
// disable the gui until the repos are scanned
|
|
|
|
me.release.box.Disable()
|
2024-02-20 16:11:00 -06:00
|
|
|
me.Disable()
|
2024-02-20 14:44:38 -06:00
|
|
|
|
2024-02-20 16:11:00 -06:00
|
|
|
// register a Show/Hide function for the repo list table
|
2024-02-26 21:46:34 -06:00
|
|
|
me.repos.View.RegisterHideFunction(hideFunction)
|
2024-02-20 16:11:00 -06:00
|
|
|
|
|
|
|
// scan in the State of all the repos
|
2024-02-18 17:55:59 -06:00
|
|
|
// TODO: should not really be necessary directly after init()
|
2024-02-20 16:11:00 -06:00
|
|
|
me.repos.View.ScanRepositories()
|
|
|
|
|
2024-11-22 08:41:37 -06:00
|
|
|
loop := me.repos.View.ReposSortByName()
|
|
|
|
for loop.Scan() {
|
|
|
|
repo := loop.Repo()
|
2024-12-03 13:23:55 -06:00
|
|
|
if me.forge.Config.IsReadOnly(repo.GoPath()) {
|
2024-11-22 08:41:37 -06:00
|
|
|
repo.Status.SetReadOnly(true)
|
|
|
|
} else {
|
|
|
|
repo.Status.SetReadOnly(false)
|
|
|
|
}
|
2024-12-05 12:49:07 -06:00
|
|
|
if me.forge.Config.IsPrivate(repo.GoPath()) {
|
2024-11-22 08:41:37 -06:00
|
|
|
repo.Status.SetPrivate(true)
|
|
|
|
} else {
|
|
|
|
repo.Status.SetPrivate(false)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-13 20:32:07 -06:00
|
|
|
pwd, _ := os.Getwd()
|
|
|
|
basedir := strings.TrimPrefix(pwd, me.forge.GetGoSrc())
|
|
|
|
basedir = strings.Trim(basedir, "/")
|
|
|
|
me.startRepo = me.forge.Repos.FindByGoPath(basedir)
|
2024-03-09 22:02:32 -06:00
|
|
|
|
2024-12-13 19:30:12 -06:00
|
|
|
if me.startRepo == nil {
|
2024-12-13 20:32:07 -06:00
|
|
|
log.Info("Can not run if pwd is not a repo", basedir)
|
2024-02-20 16:11:00 -06:00
|
|
|
os.Exit(0)
|
|
|
|
}
|
2024-02-18 17:55:59 -06:00
|
|
|
me.Enable()
|
|
|
|
|
2024-12-02 05:13:17 -06:00
|
|
|
// set all branches to master & findNext()
|
|
|
|
makePrepareRelease()
|
|
|
|
|
2024-02-18 17:55:59 -06:00
|
|
|
// intermittently scans the status indefinitly
|
|
|
|
me.repos.View.Watchdog(func() {
|
|
|
|
log.Info("In main()")
|
|
|
|
// processing is done. update the repo summary box
|
|
|
|
// me.summary.Update()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-02-19 14:40:21 -06:00
|
|
|
// start the initail scan and make sure each repo is set
|
|
|
|
// to the master branch
|
2024-02-20 14:44:38 -06:00
|
|
|
func setAllBranchesToMaster() bool {
|
|
|
|
var worked bool = true
|
2024-11-16 00:07:53 -06:00
|
|
|
loop := me.repos.View.ReposSortByName()
|
|
|
|
for loop.Scan() {
|
|
|
|
repo := loop.Repo()
|
2024-02-20 14:44:38 -06:00
|
|
|
if repo.ReadOnly() {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if repo.IsDirty() {
|
|
|
|
continue
|
|
|
|
}
|
2024-11-13 18:13:20 -06:00
|
|
|
if repo.Status.Whitelist {
|
2024-02-19 19:42:14 -06:00
|
|
|
continue
|
|
|
|
}
|
2024-02-18 17:55:59 -06:00
|
|
|
if repo.Status.CheckoutMaster() {
|
|
|
|
log.Warn("git checkout master branch worked", repo.Name())
|
|
|
|
} else {
|
|
|
|
log.Warn("git checkout master branch failed", repo.Name())
|
2024-02-20 14:44:38 -06:00
|
|
|
worked = false
|
2024-02-18 17:55:59 -06:00
|
|
|
}
|
2024-02-19 19:42:14 -06:00
|
|
|
// repo.NewScan()
|
2024-02-18 17:55:59 -06:00
|
|
|
}
|
2024-02-20 14:44:38 -06:00
|
|
|
return worked
|
2024-02-19 14:40:21 -06:00
|
|
|
}
|