package main import ( "fmt" "os" "go.wit.com/log" "go.wit.com/gui" "go.wit.com/lib/gui/repolist" "go.wit.com/lib/protobuf/forgepb" ) // sent via -ldflags var VERSION string var BUILDTIME string func main() { me = new(autoType) // load the ~/.config/forge/ config me.forge = forgepb.Init() if me.forge == nil { panic("damn it, forge is nil") } if me.forge.Config == nil { panic("damn it config") } me.forge.ConfigPrintTable() // setup the GUI me.myGui = gui.New() me.myGui.Default() // todo: this code sucks. fix it soon me.mainWindow = me.myGui.NewWindow("builds and uploads all the packages") me.mainbox = me.mainWindow.NewBox("bw hbox", true) // make a window with a table of all the repos me.repoList = repolist.AutotypistView(me.mainbox) me.repoList.Init(me.forge) me.Enable() failed := make(map[*repolist.RepoRow]string) versions := make(map[*repolist.RepoRow]string) rloop := me.repoList.ReposSortByName() for rloop.Scan() { repo := rloop.Repo() // var cmd []string var start string var end string var alreadyBuilt bool ver := repo.Status.DebianReleaseVersion() name := me.forge.DebName(repo.GoPath()) if me.machine.IsInstalled(name) { end += "(installed) " } if actualp := me.machine.FindVersion(name, ver); actualp != nil { end += " (version match) " + actualp.Version + " " + ver + " " alreadyBuilt = true } else { end += " (need to build) " + ver + " " } if alreadyBuilt { start = fmt.Sprintf("already built %-30s %-8s %-50s", name, ver, repo.GoPath()) } else { start = fmt.Sprintf("need to build %-30s %-8s %-50s", name, ver, repo.GoPath()) } log.Info(start, "("+versions[repo]+")", end) if name == "" { // err := fmt.Sprintf("name is blank error %+v", repo) log.Warn("name is blank error", repo.GoPath()) } if argv.DryRun { continue } // skip if already built. (unless --force) if alreadyBuilt { // don't rebuild things if argv.Force { // well, okay, force me to rebuild them then } else { continue } } if repo.Status.IsPrivate() { // cmd = []string{"go-deb", "--auto", "--repo", repo.GoPath()} } else { } } log.Info("") log.Info("something failed on:") var fail bool = true for repo, cmd := range failed { log.Info("failed cmd :", cmd, repo.Status.Path()) fail = false } if fail { os.Exit(0) } os.Exit(-1) }