go-mod-clean/redoGoMod.go

118 lines
3.2 KiB
Go
Raw Normal View History

2024-12-13 02:21:25 -06:00
package main
// recreates the go.mod and go.sum files
import (
"errors"
"os"
2024-12-18 00:41:52 -06:00
"strings"
2024-12-13 02:21:25 -06:00
2024-12-18 00:41:52 -06:00
"github.com/go-cmd/cmd"
2024-12-13 02:21:25 -06:00
"go.wit.com/lib/protobuf/gitpb"
"go.wit.com/log"
)
// remove every go.mod and go.sum
// testing to see where this stuff is coming from
func eraseGoMod(repo *gitpb.Repo) {
// unset the go development ENV var to generate release files
if err := repo.StrictRun([]string{"rm", "-f", "go.mod", "go.sum"}); err != nil {
2024-12-17 07:03:07 -06:00
log.Warn(repo.GetGoPath(), "rm go.mod go.sum failed", err)
2024-12-13 02:21:25 -06:00
}
}
// sets the required golang version in go.mod
func setGoVersion(repo *gitpb.Repo, version string) error {
if err := repo.StrictRun([]string{"go", "mod", "edit", "-go=" + version}); err != nil {
2024-12-17 07:03:07 -06:00
log.Warn(repo.GetGoPath(), "go mod edit failed", err)
2024-12-13 02:21:25 -06:00
return err
}
return nil
}
2024-12-18 00:41:52 -06:00
func goTidy(fullpath string) (cmd.Status, error) {
if result, err := runVerbose(fullpath, []string{"go", "mod", "tidy", "-go=" + golangVersion}); err == nil {
return result, nil
} else {
return result, err
}
}
2024-12-13 02:21:25 -06:00
// wrapper around 'go mod init' and 'go mod tidy'
2024-12-13 16:16:18 -06:00
func redoGoMod(repo *gitpb.Repo) error {
2024-12-13 02:21:25 -06:00
// unset the go development ENV var to generate release files
os.Unsetenv("GO111MODULE")
if err := repo.StrictRun([]string{"rm", "-f", "go.mod", "go.sum"}); err != nil {
log.Warn("rm go.mod go.sum failed", err)
2024-12-13 16:16:18 -06:00
return err
2024-12-13 02:21:25 -06:00
}
2024-12-17 07:03:07 -06:00
if err := repo.StrictRun([]string{"go", "mod", "init", repo.GetGoPath()}); err != nil {
2024-12-13 02:21:25 -06:00
log.Warn("go mod init failed", err)
2024-12-13 16:16:18 -06:00
return err
2024-12-13 02:21:25 -06:00
}
2024-12-18 00:41:52 -06:00
if result, err := goTidy(repo.FullPath); err != nil {
if tinyFixer(result) {
if _, err := goTidy(repo.FullPath); err != nil {
return err
}
}
2024-12-13 02:21:25 -06:00
}
2024-12-15 08:46:01 -06:00
// most things should build with golang after 1.21 // todo: allow this to be set somewhere
2024-12-18 00:41:52 -06:00
if err := setGoVersion(repo, golangVersion); err != nil {
2024-12-17 07:03:07 -06:00
log.Warn(repo.GetGoPath(), "go mod edit failed", err)
2024-12-13 16:16:18 -06:00
return err
2024-12-13 02:21:25 -06:00
}
repo.GoDeps = nil
2024-12-17 20:47:09 -06:00
repo.SetGoPrimitive(false)
2024-12-13 02:21:25 -06:00
// if there is not a go.sum file, it better be a primitive golang project
if !repo.Exists("go.sum") {
2024-12-13 16:16:18 -06:00
// todo. fix this logic
2024-12-17 20:47:09 -06:00
err := repo.SetPrimitive()
2024-12-13 02:21:25 -06:00
if err != nil {
// this means this repo does not depend on any other package
2024-12-17 07:03:07 -06:00
log.Info("PRIMATIVE repo error:", repo.GetGoPath(), "err =", err)
2024-12-13 16:16:18 -06:00
return err
2024-12-13 02:21:25 -06:00
}
2024-12-17 20:47:09 -06:00
}
2024-12-13 02:21:25 -06:00
2024-12-17 20:47:09 -06:00
// now check if GoPrimitive is true
if repo.GetGoPrimitive() {
// perfect!
return nil
2024-12-13 02:21:25 -06:00
}
2024-12-17 20:47:09 -06:00
// well, it's not a primitive and we are still missing the go.sum file
2024-12-13 02:21:25 -06:00
if !repo.Exists("go.sum") {
2024-12-17 20:47:09 -06:00
// this means something else went wrong!
// display the go.mod file and try to figure out what happened
// maybe the format of go.mod changed in some future version of golang
2024-12-13 16:16:18 -06:00
data, _ := repo.ReadFile("go.mod")
log.Info(string(data))
return errors.New("missing go.sum file on non-primitive go.mod")
2024-12-13 02:21:25 -06:00
}
2024-12-13 16:16:18 -06:00
repo.GoDeps = new(gitpb.GoDeps)
2024-12-13 02:21:25 -06:00
// return the attempt to parse go.sum
2024-12-13 16:16:18 -06:00
_, err := repo.ParseGoSum()
return err
2024-12-13 02:21:25 -06:00
}
2024-12-18 00:41:52 -06:00
func tinyFixer(result cmd.Status) bool {
for _, line := range result.Stdout {
if strings.Contains(line, "requires go@") {
log.Info("tinyFixer:", line)
parts := strings.Split(line, "requires go@")
if len(parts) == 2 {
parts = strings.Split(parts[1], ",")
golangVersion = parts[0]
return true
}
log.Info("tinyFixer:", line, "golangVersion", golangVersion)
}
}
return false
}