autotypist/globalBuildOptions.go

205 lines
5.5 KiB
Go
Raw Normal View History

package main
import (
"os"
"os/user"
"path/filepath"
"go.wit.com/log"
"go.wit.com/gui"
"go.wit.com/lib/gadgets"
2024-02-17 08:38:44 -06:00
"go.wit.com/lib/gui/repolist"
)
func globalBuildOptions(vbox *gui.Node) {
group1 := vbox.NewGroup("Global Build Options")
2024-02-16 17:55:53 -06:00
grid := group1.NewGrid("buildOptions", 0, 0)
// me.autoWorkingPwd = gadgets.NewOneLiner(grid, "working directory (pwd)")
me.userHomePwd = gadgets.NewOneLiner(grid, "user home")
2024-02-16 17:55:53 -06:00
grid.NextRow()
me.goSrcPwd = gadgets.NewOneLiner(grid, "go src home")
2024-02-16 17:55:53 -06:00
grid.NextRow()
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-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' ?
// 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-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")
})
*/