]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/dist: wait for exit in bgwait after a fatal error
authorManlio Perillo <manlio.perillo@gmail.com>
Sun, 16 May 2021 17:52:37 +0000 (19:52 +0200)
committerIan Lance Taylor <iant@golang.org>
Tue, 9 Nov 2021 21:58:03 +0000 (21:58 +0000)
Currently, when a command scheduled by bgrun fails, bgwait returns to
the caller even in case the fatal error was detected.

In case of a syntax error in one of the standard packages, as an
example, the runInstall function will try to read the generated archive
file, only to fail since the file does not exist.  Since the runInstall
function is called in a goroutine, cmd/dist will continue to report
errors until all background goroutines are done.

Update the bgwait function to wait until program termination in case of
a fatal error, since returning to the caller (with an error, as an
example) will cause cmd/dist to report an additional error during the
next build phase.

Fixes #45410

Change-Id: If89976abad70f8d6ec79b2a5a1f2306e9c034c5a
Reviewed-on: https://go-review.googlesource.com/c/go/+/320311
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: Ian Lance Taylor <iant@golang.org>
Trust: Dmitri Shuralyov <dmitshur@golang.org>

src/cmd/dist/util.go

index 28fe5e1d8d20d5f02ba573bef5ae633a02e47759..8856f467d5ba8e66ed4ad851ed3ea4abc9efdf8a 100644 (file)
@@ -172,6 +172,9 @@ func bgwait(wg *sync.WaitGroup) {
        select {
        case <-done:
        case <-dying:
+               // Don't return to the caller, to avoid reporting additional errors
+               // to the user.
+               select {}
        }
 }