better "ForgeMode" handling

This commit is contained in:
Jeff Carr 2025-09-13 01:46:53 -05:00
parent da0fc653ae
commit 20fe78266c
5 changed files with 15 additions and 39 deletions

View File

@ -6,6 +6,7 @@ package main
import ( import (
"fmt" "fmt"
"go.wit.com/lib/config"
"go.wit.com/lib/protobuf/forgepb" "go.wit.com/lib/protobuf/forgepb"
) )
@ -13,36 +14,11 @@ func forgeConfigSave() error {
return me.forge.Config.ConfigSave() return me.forge.Config.ConfigSave()
} }
/* func setForgeMode(fmode forgepb.ForgeMode) {
func configInit() (*forgepb.ForgeConfigs, error) { me.forge.Config.Mode = fmode
me.urlbase = argv.URL config.SetChanged("forge", true)
if me.urlbase == "" { me.forge.Config.ConfigSave()
me.urlbase = "https://go.wit.com/"
} }
if os.Getenv("FORGE_URL") != "" {
me.urlbase = os.Getenv("FORGE_URL")
log.Info("got forge url", me.urlbase)
}
me.urlbase = strings.Trim(me.urlbase, "/") // track down why trailing '/' makes http POST not work
configs := new(forgepb.ForgeConfigs)
err := config.ConfigLoad(configs, ARGNAME, "forge")
if errors.Is(err, os.ErrNotExist) {
// if forgepb.FirstTimeUser() {
log.Info("You are running forge for the first time here")
// }
configs.ReposDir = "/home/forge"
configs.ReposPB = "/home/forge/repos.pb"
configs.PatchDir = "/var/lib/forged"
if err := forgeConfigSave(); err != nil {
return nil, err
}
log.Info("WARNING: made a new default config file here", configs.Filename)
okExit("")
}
return configs, err
}
*/
func sampleConfig(all *forgepb.ForgeConfigs) { func sampleConfig(all *forgepb.ForgeConfigs) {
new1 := new(forgepb.ForgeConfig) new1 := new(forgepb.ForgeConfig)

View File

@ -8,6 +8,7 @@ import (
"time" "time"
"go.wit.com/lib/gui/shell" "go.wit.com/lib/gui/shell"
"go.wit.com/lib/protobuf/forgepb"
"go.wit.com/log" "go.wit.com/log"
) )
@ -33,6 +34,8 @@ func doCheckout() error {
} }
if argv.Checkout.Master != nil { if argv.Checkout.Master != nil {
setForgeMode(forgepb.ForgeMode_MASTER) // disable "normal" mode if set
if err := me.forge.DoAllCheckoutMaster(); err != nil { if err := me.forge.DoAllCheckoutMaster(); err != nil {
badExit(err) badExit(err)
} }

View File

@ -32,7 +32,7 @@ func checkRemoteBranches(repo *gitpb.Repo) error {
// reverts all repos back to the original master branches // reverts all repos back to the original master branches
// automatically deletes local devel and user branches // automatically deletes local devel and user branches
func doClean() error { func doClean() error {
me.forge.Config.Mode = forgepb.ForgeMode_CLEAN setForgeMode(forgepb.ForgeMode_CLEAN)
if argv.Clean.Verify != nil { if argv.Clean.Verify != nil {
stats := me.forge.RillRepos(checkRemoteBranches) stats := me.forge.RillRepos(checkRemoteBranches)

View File

@ -59,8 +59,8 @@ func doMergeDevel() (*gitpb.Repos, error) {
func doMergeMaster() (*gitpb.Repos, error) { func doMergeMaster() (*gitpb.Repos, error) {
var err error var err error
me.forge.Config.Mode = forgepb.ForgeMode_MASTER // disable "normal" mode if set setForgeMode(forgepb.ForgeMode_MASTER)
configSave = true
done := gitpb.NewRepos() done := gitpb.NewRepos()
found := findMergeToMaster() found := findMergeToMaster()
for repo := range found.IterAll() { for repo := range found.IterAll() {

11
main.go
View File

@ -82,7 +82,7 @@ func main() {
} }
if argv.Checkout != nil { if argv.Checkout != nil {
me.forge.Config.Mode = forgepb.ForgeMode_MASTER setForgeMode(forgepb.ForgeMode_MASTER)
if err := doCheckout(); err != nil { if err := doCheckout(); err != nil {
badExit(err) badExit(err)
} }
@ -132,8 +132,7 @@ func main() {
log.Info("you are already in the normal state") log.Info("you are already in the normal state")
okExit("") okExit("")
} }
me.forge.Config.Mode = forgepb.ForgeMode_NORMAL setForgeMode(forgepb.ForgeMode_NORMAL)
me.forge.Config.ConfigSave()
log.Info("normal mode on") log.Info("normal mode on")
okExit("") okExit("")
} }
@ -143,8 +142,7 @@ func main() {
log.Info("you were aleady not in the normal state") log.Info("you were aleady not in the normal state")
okExit("") okExit("")
} }
me.forge.Config.Mode = forgepb.ForgeMode_MASTER setForgeMode(forgepb.ForgeMode_MASTER)
me.forge.Config.ConfigSave()
log.Info("normal mode off") log.Info("normal mode off")
okExit("") okExit("")
} }
@ -153,8 +151,7 @@ func main() {
log.Infof("all %d repos are on your user branch. It is safe to write code now.\n", me.forge.Repos.Len()) log.Infof("all %d repos are on your user branch. It is safe to write code now.\n", me.forge.Repos.Len())
if me.forge.Config.Mode != forgepb.ForgeMode_NORMAL { if me.forge.Config.Mode != forgepb.ForgeMode_NORMAL {
log.Infof("Forge has set the mode to 'Normal'\n") log.Infof("Forge has set the mode to 'Normal'\n")
me.forge.Config.Mode = forgepb.ForgeMode_NORMAL setForgeMode(forgepb.ForgeMode_NORMAL)
me.forge.ConfigSave()
} }
okExit("") okExit("")
} }