diff --git a/go.mod b/go.mod index b66e3498..c427c54b 100644 --- a/go.mod +++ b/go.mod @@ -6,7 +6,7 @@ require ( github.com/bluekeyes/go-gitdiff v0.8.0 github.com/go-quicktest/qt v1.101.0 github.com/google/go-cmp v0.6.0 - github.com/rogpeppe/go-internal v1.13.1 + github.com/rogpeppe/go-internal v1.13.2-0.20241226121412-a5dc8ff20d0a golang.org/x/mod v0.22.0 golang.org/x/tools v0.27.0 ) diff --git a/go.sum b/go.sum index 34f422d6..a482f435 100644 --- a/go.sum +++ b/go.sum @@ -11,8 +11,8 @@ github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= -github.com/rogpeppe/go-internal v1.13.1 h1:KvO1DLK/DRN07sQ1LQKScxyZJuNnedQ5/wKSR38lUII= -github.com/rogpeppe/go-internal v1.13.1/go.mod h1:uMEvuHeurkdAXX61udpOXGD/AzZDWNMNyH2VO9fmH0o= +github.com/rogpeppe/go-internal v1.13.2-0.20241226121412-a5dc8ff20d0a h1:w3tdWGKbLGBPtR/8/oO74W6hmz0qE5q0z9aqSAewaaM= +github.com/rogpeppe/go-internal v1.13.2-0.20241226121412-a5dc8ff20d0a/go.mod h1:S8kfXMp+yh77OxPD4fdM6YUknrZpQxLhvxzS4gDHENY= golang.org/x/mod v0.22.0 h1:D4nJWe9zXqHOmWqj4VMOJhvzj7bEZg4wEYa759z1pH4= golang.org/x/mod v0.22.0/go.mod h1:6SkKJ3Xj0I0BrPOZoBy3bdMptDDU9oJrpohJ3eWZ1fY= golang.org/x/sync v0.9.0 h1:fEo0HyrW1GIgZdpbhCRO0PkJajUS5H9IFUztCgEo2jQ= diff --git a/main.go b/main.go index 81adefac..f3ce667f 100644 --- a/main.go +++ b/main.go @@ -146,8 +146,6 @@ For more information, see https://github.com/burrowers/garble. `[1:]) } -func main() { os.Exit(main1()) } - var ( // Presumably OK to share fset across packages. fset = token.NewFileSet() @@ -220,7 +218,7 @@ func debugSince(start time.Time) time.Duration { return time.Since(start).Truncate(10 * time.Microsecond) } -func main1() int { +func main() { if dir := os.Getenv("GARBLE_WRITE_CPUPROFILES"); dir != "" { f, err := os.CreateTemp(dir, "garble-cpu-*.pprof") if err != nil { @@ -257,7 +255,7 @@ func main1() int { } }() if err := flagSet.Parse(os.Args[1:]); err != nil { - return 2 + os.Exit(2) } log.SetPrefix("[garble] ") log.SetFlags(0) // no timestamps, as they aren't very useful @@ -270,7 +268,7 @@ func main1() int { args := flagSet.Args() if len(args) < 1 { usage() - return 2 + os.Exit(2) } // If a random seed was used, the user won't be able to reproduce the @@ -283,12 +281,11 @@ func main1() int { } if err := mainErr(args); err != nil { if code, ok := err.(errJustExit); ok { - return int(code) + os.Exit(int(code)) } fmt.Fprintln(os.Stderr, err) - return 1 + os.Exit(1) } - return 0 } type errJustExit int diff --git a/main_test.go b/main_test.go index 0ea0a349..396365ed 100644 --- a/main_test.go +++ b/main_test.go @@ -41,11 +41,11 @@ func TestMain(m *testing.M) { os.Setenv("GORACE", "atexit_sleep_ms=10") } if os.Getenv("RUN_GARBLE_MAIN") == "true" { - os.Exit(main1()) + main() } - os.Exit(testscript.RunMain(garbleMain{m}, map[string]func() int{ - "garble": main1, - })) + testscript.Main(garbleMain{m}, map[string]func(){ + "garble": main, + }) } type garbleMain struct {