2024-01-16 04:46:17 -06:00
|
|
|
package main
|
|
|
|
|
2024-01-18 00:58:14 -06:00
|
|
|
import (
|
2024-01-16 04:46:17 -06:00
|
|
|
"os"
|
2024-01-30 17:22:46 -06:00
|
|
|
"os/user"
|
2024-01-26 14:21:05 -06:00
|
|
|
"path/filepath"
|
2024-01-16 04:46:17 -06:00
|
|
|
|
|
|
|
"go.wit.com/log"
|
|
|
|
|
2024-01-18 05:03:04 -06:00
|
|
|
"go.wit.com/gui"
|
2024-01-18 00:58:14 -06:00
|
|
|
"go.wit.com/lib/gadgets"
|
2024-02-17 08:38:44 -06:00
|
|
|
"go.wit.com/lib/gui/repolist"
|
2024-01-16 04:46:17 -06:00
|
|
|
)
|
|
|
|
|
2024-02-12 15:24:35 -06:00
|
|
|
func globalBuildOptions(vbox *gui.Node) {
|
2024-01-20 17:17:48 -06:00
|
|
|
group1 := vbox.NewGroup("Global Build Options")
|
2024-02-16 17:55:53 -06:00
|
|
|
grid := group1.NewGrid("buildOptions", 0, 0)
|
2024-01-16 04:46:17 -06:00
|
|
|
|
2024-02-13 09:18:04 -06:00
|
|
|
// me.autoWorkingPwd = gadgets.NewOneLiner(grid, "working directory (pwd)")
|
2024-01-30 23:38:46 -06:00
|
|
|
me.userHomePwd = gadgets.NewOneLiner(grid, "user home")
|
2024-02-16 17:55:53 -06:00
|
|
|
grid.NextRow()
|
2024-01-30 23:38:46 -06:00
|
|
|
me.goSrcPwd = gadgets.NewOneLiner(grid, "go src home")
|
2024-02-16 17:55:53 -06:00
|
|
|
grid.NextRow()
|
2024-01-30 23:38:46 -06:00
|
|
|
|
|
|
|
usr, _ := user.Current()
|
|
|
|
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)
|
2024-02-24 11:54:47 -06:00
|
|
|
grid.NextRow()
|
|
|
|
|
|
|
|
grid.NewGroup("git checkout")
|
|
|
|
// checking this will automatically make the branches off of devel
|
|
|
|
grid.NextRow()
|
2024-02-29 17:29:19 -06:00
|
|
|
me.autoCreateBranches = grid.NewCheckbox("auto-create branches if not upstream").SetChecked(true)
|
2024-02-25 13:09:56 -06:00
|
|
|
me.autoCreateBranches.Custom = func() {
|
|
|
|
if me.autoCreateBranches.Checked() {
|
|
|
|
os.Setenv("AUTOTYPIST_CREATE_BRANCHES", "on")
|
|
|
|
} else {
|
|
|
|
os.Unsetenv("AUTOTYPIST_CREATE_BRANCHES")
|
|
|
|
}
|
|
|
|
}
|
2024-02-24 11:54:47 -06:00
|
|
|
grid.NextRow()
|
|
|
|
|
2024-02-25 09:43:11 -06:00
|
|
|
grid.NewButton("git checkout default", func() {
|
2024-02-25 13:09:56 -06:00
|
|
|
me.repos.View.ArgCheckoutMaster()
|
2024-02-24 11:54:47 -06:00
|
|
|
})
|
2024-02-29 17:29:19 -06:00
|
|
|
grid.NewLabel("master,main,etc.") // set the order of these in the config file ?
|
2024-02-24 11:54:47 -06:00
|
|
|
grid.NextRow()
|
|
|
|
|
2024-02-25 09:43:11 -06:00
|
|
|
grid.NewButton("git checkout devel", func() {
|
2024-02-24 11:54:47 -06:00
|
|
|
me.repos.View.ArgCheckoutDevel()
|
|
|
|
})
|
2024-02-29 17:29:19 -06:00
|
|
|
grid.NewLabel("guidevel,devel") // set the order of these in the config file ?
|
2024-02-24 11:54:47 -06:00
|
|
|
grid.NextRow()
|
2024-01-30 23:38:46 -06:00
|
|
|
|
2024-02-25 09:43:11 -06:00
|
|
|
grid.NewButton("git checkout user", func() {
|
2024-02-24 11:54:47 -06:00
|
|
|
me.repos.View.ArgCheckoutUser()
|
|
|
|
})
|
|
|
|
grid.NewLabel(usr.Username)
|
|
|
|
grid.NextRow()
|
2024-02-25 13:09:56 -06:00
|
|
|
|
|
|
|
// select the branches you want to test, build and develop against
|
|
|
|
// let's call this the 'mode' ?
|
2024-01-16 04:46:17 -06:00
|
|
|
// 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
|
|
|
|
// works. Then, when that is good, merge and version everything in master
|
2024-02-25 13:09:56 -06:00
|
|
|
/*
|
|
|
|
if repo.Status.BranchExists(targetName) {
|
|
|
|
ok := repo.Status.CheckoutBranch(targetName)
|
|
|
|
if ok {
|
|
|
|
// checkout went fine
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
log.Info("couldn't set", repo.Status.Path(), "branch to", targetName)
|
|
|
|
log.Info("but branch exists so something went wrong")
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if !me.autoCreateBranches.Checked() {
|
|
|
|
log.Info("not auto creating branch", targetName)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
// branch doesn't exist. make it
|
|
|
|
// todo: make this branch from 'devel' branch if it exists
|
|
|
|
log.Info("should make the", targetName, "branch here!")
|
|
|
|
if me.autoCreateBranches.Checked() {
|
|
|
|
log.Info("going to make the branch!")
|
|
|
|
repo.Status.RunCmd([]string{"git", "branch", targetName})
|
|
|
|
repo.Status.RunCmd([]string{"git", "checkout", targetName})
|
|
|
|
} else {
|
|
|
|
log.Info("not auto creating branch", targetName)
|
|
|
|
}
|
|
|
|
repo.Scan()
|
|
|
|
count += 1
|
|
|
|
*/
|
2024-02-16 17:55:53 -06:00
|
|
|
|
|
|
|
grid.NextRow()
|
2024-02-29 17:29:19 -06:00
|
|
|
|
|
|
|
grid.NewGroup("update from upstream")
|
2024-03-02 07:44:18 -06:00
|
|
|
grid.NextRow()
|
2024-02-29 17:29:19 -06:00
|
|
|
grid.NewButton("git fetch master & devel branches", func() {
|
2024-02-25 09:43:11 -06:00
|
|
|
me.Disable()
|
|
|
|
defer me.Enable()
|
|
|
|
log.Warn("updating all master branches")
|
|
|
|
var count, failed int
|
|
|
|
for _, repo := range repolist.AllRepos() {
|
|
|
|
var err error
|
|
|
|
var out string
|
|
|
|
count += 1
|
|
|
|
if err, out = repo.Status.FetchMaster(); err != nil {
|
|
|
|
log.Warn(repo.Name(), "fetch failed", err, out)
|
|
|
|
failed += 1
|
|
|
|
} else {
|
|
|
|
log.Warn(repo.Name(), "fetch sent:", out)
|
|
|
|
}
|
|
|
|
if err, out = repo.Status.FetchDevel(); err != nil {
|
|
|
|
log.Warn(repo.Name(), "fetch failed", err, out)
|
|
|
|
failed += 1
|
|
|
|
} else {
|
|
|
|
log.Warn(repo.Name(), "fetch sent:", out)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
log.Warn("updated all master branches", count, "failed =", failed)
|
|
|
|
})
|
2024-01-16 04:46:17 -06:00
|
|
|
}
|
2024-02-20 10:58:58 -06:00
|
|
|
|
|
|
|
// this code isn't ready yet
|
|
|
|
/*
|
|
|
|
s.gitPullB = grid.NewButton("git pull", func() {
|
|
|
|
me.Disable()
|
|
|
|
defer me.Enable()
|
|
|
|
for _, repo := range repolist.AllRepos() {
|
|
|
|
// gitcmd := []string{"git", "fetch", "origin"}
|
2024-02-22 05:24:02 -06:00
|
|
|
itcmd := []string{"git", "pull"}
|
2024-02-20 10:58:58 -06:00
|
|
|
err, output := repo.RunCmd(gitcmd)
|
|
|
|
log.Info("output =", output)
|
|
|
|
if err == nil {
|
|
|
|
log.Info("git fetch worked", repo.Name())
|
|
|
|
} else {
|
|
|
|
log.Info("git fetch failed", repo.Name())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
gitPullB.SetText("GOOD")
|
|
|
|
// update the stats
|
|
|
|
// s.Update()
|
|
|
|
})
|
|
|
|
|
|
|
|
s.gitPushB = grid.NewButton("git push", func() {
|
|
|
|
me.Disable()
|
|
|
|
defer me.Enable()
|
|
|
|
for _, repo := range repolist.AllRepos() {
|
|
|
|
gitcmd := []string{"git", "push"}
|
|
|
|
err, output := repo.RunCmd(gitcmd)
|
|
|
|
log.Info("output =", output)
|
|
|
|
if err == nil {
|
|
|
|
log.Info("git push worked", repo.Name())
|
|
|
|
} else {
|
|
|
|
log.Info("git push failed", repo.Name())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
s.gitPushB.SetText("GOOD")
|
|
|
|
// update the stats
|
|
|
|
s.Update()
|
|
|
|
})
|
|
|
|
|
|
|
|
s.checkB = s.grid.NewButton("Check repos are working", func() {
|
|
|
|
me.Disable()
|
|
|
|
defer me.Enable()
|
|
|
|
for _, repo := range repolist.AllRepos() {
|
|
|
|
if repo.GitURL() != "" {
|
|
|
|
log.Info("repo already checked. do they match?")
|
|
|
|
log.Info("go.wit.com =", repo.GoURL())
|
|
|
|
log.Info("localurl =", repo.Path())
|
|
|
|
} else {
|
|
|
|
ok, giturl := gowit.CheckRegistered(repo)
|
|
|
|
if ok {
|
|
|
|
log.Info("is url correct?", repo.Path(), "vs", giturl)
|
|
|
|
repo.giturl = giturl
|
|
|
|
if giturl != repo.Path() {
|
|
|
|
log.Info("repo check failed", repo.String())
|
|
|
|
s.unknownOL.SetText(repo.String())
|
|
|
|
s.unknownOL.Show()
|
|
|
|
s.unknownSubmitB.Show()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
log.Info("repo check failed", repo.String())
|
|
|
|
repo.giturl = "look in .git/config"
|
|
|
|
s.unknownOL.SetText(repo.String())
|
|
|
|
s.unknownOL.Show()
|
|
|
|
s.unknownSubmitB.Show()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
s.checkB.SetText("GOOD")
|
|
|
|
})
|
|
|
|
*/
|