package forgepb import ( "os" "os/user" "path/filepath" "time" "go.wit.com/lib/gui/shell" "go.wit.com/lib/protobuf/gitpb" "go.wit.com/lib/protobuf/zoopb" "go.wit.com/log" ) // todo: use initOnce // cache.go has Do() // f.initOnce.Do(f.initWork) func Init() *Forge { f := InitPB() f.Machine = new(zoopb.Machine) if err := f.Machine.ConfigLoad(); err != nil { log.Log(WARN, "zoopb.ConfigLoad() failed", err) } if f.Config.Username == "" { usr, _ := user.Current() f.Config.Username = usr.Username f.SetConfigSave(true) } f.Machine.InitWit() now := time.Now() start := f.Repos.Len() f.ScanGoSrc() end := f.Repos.Len() if (end - start) == 0 { log.Log(INFO, "forgepb.Scan() Scan did not find new git repositories. Total =", end) } else { log.Log(INFO, "forgepb.Scan() Scan found", end-start, "new git repositories. Total =", end) } f.rillUpdate(20, 10) if f.configSave { // taking this out to debug Marshal() panic // os.Exit(-1) f.ConfigSave() f.configSave = false } log.Log(INFO, "update() check took", shell.FormatDuration(time.Since(now))) return f } func DetermineGoPath() *Forge { f := new(Forge) // TODO: rethink this but it works for now gosrc := os.Getenv("FORGE_GOSRC") if gosrc == "" { goSrcDir, err := f.findGoSrc() if err != nil { log.Log(WARN, "forge init() findGoSrc()", err) } os.Setenv("FORGE_GOSRC", goSrcDir) } f.goSrc = os.Getenv("FORGE_GOSRC") // also rethink this, but maybe this is the right thing to do if os.Getenv("FORGE_CONFIG") == "" { homeDir, _ := os.UserHomeDir() fullpath := filepath.Join(homeDir, ".config/forge") os.Setenv("FORGE_CONFIG", fullpath) } // check again for go.work // user could have a go.work file in ~/go/src if f.goWorkExists() { f.goWork = true } // print out the settings that will be used log.Log(INFO, "forgepb.Init() FORGE_CONFIG", os.Getenv("FORGE_CONFIG")) return f } func (f *Forge) InitPB() { // load the ~/.config/forge/ config f.Config = new(ForgeConfigs) if err := f.Config.ConfigLoad(); err != nil { log.Log(WARN, "forgepb.ConfigLoad() failed", err) } if f.IsGoWork() { log.Log(INFO, "forgepb.Init() FORGE_GOSRC ", os.Getenv("FORGE_GOSRC"), "(go.work = true)") } else { log.Log(INFO, "forgepb.Init() FORGE_GOSRC ", os.Getenv("FORGE_GOSRC"), "(go.work = false)") } f.Repos = new(gitpb.Repos) f.Repos.ConfigLoad() } // only init's the protobuf. intended to not scan or change anything func InitPB() *Forge { f := DetermineGoPath() f.InitPB() return f } func (f *Forge) SetConfigSave(b bool) { f.configSave = b } // saves the config if there have been changes func (f *Forge) Exit() { // log.Info("forge.configSave =", f.configSave) if f.configSave { f.ConfigSave() } // log.Info("forge.Exit() ok") os.Exit(0) }