package main import ( "go.wit.com/lib/protobuf/gitpb" "go.wit.com/log" ) // this will make go.mod and go.sum files, but you have to // have the files in .gitignore for now func doSmart(repo *gitpb.Repo) error { // erase the go.mod and go.sum files eraseGoMod(repo) // if the repo has go.mod in the repo... if err := repo.RepoIgnoresGoMod(); err != nil { if repo.ParseGoSum() { return nil } log.Info("go-mod-clean can not run on this repo", repo.GetGoPath()) log.Info("go.mod and go.sum must be git metadata to continue") // return nil } if repo.Exists("go.mod") { return nil } // try to restore from the git metadata cname := repo.GetCurrentBranchName() if err := repo.AutogenRestore(cname); err == nil { log.Info(repo.GetGoPath(), "files were restored ok from git metadata (notes)") } if repo.Exists("go.mod") { return nil } // attempt to restore from ~/go/pkg/mod/ if err := restoreFromGoPkg(repo); err == nil { log.Info(repo.GetGoPath(), "files were restored ok ~/go/mod/") } if repo.Exists("go.mod") { return nil } // actually will re-create go.sum and go.mod now if err := redoGoMod(repo); err != nil { log.Info(repo.GetGoPath(), "the files were restored with redoGoMod()") } if repo.Exists("go.mod") { return nil } // the first time, it'll attempt to fix some stuff cleanGoDepsCheckOk(repo) // try to trim junk if err := trimGoSum(repo); err != nil { } if repo.Exists("go.mod") { return nil } repo.ParseGoSum() if repo.Exists("go.mod") { return nil } // last chance. just run go mod init repo.RunVerbose([]string{"go", "mod", "init"}) return nil }