mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-13 09:32:24 -06:00
Fix issue where output could be truncated
This commit is contained in:
parent
2f2be4e936
commit
238ec05f2f
33
main.go
33
main.go
@ -6,6 +6,7 @@ import (
|
|||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"github.com/hashicorp/terraform/plugin"
|
"github.com/hashicorp/terraform/plugin"
|
||||||
"github.com/mitchellh/cli"
|
"github.com/mitchellh/cli"
|
||||||
@ -47,8 +48,9 @@ func realMain() int {
|
|||||||
|
|
||||||
// Setup the prefixed readers that send data properly to
|
// Setup the prefixed readers that send data properly to
|
||||||
// stdout/stderr.
|
// stdout/stderr.
|
||||||
|
doneCh := make(chan struct{})
|
||||||
outR, outW := io.Pipe()
|
outR, outW := io.Pipe()
|
||||||
go copyOutput(outR)
|
go copyOutput(outR, doneCh)
|
||||||
|
|
||||||
// Create the configuration for panicwrap and wrap our executable
|
// Create the configuration for panicwrap and wrap our executable
|
||||||
wrapConfig.Handler = panicHandler(logTempFile)
|
wrapConfig.Handler = panicHandler(logTempFile)
|
||||||
@ -62,6 +64,12 @@ func realMain() int {
|
|||||||
|
|
||||||
// If >= 0, we're the parent, so just exit
|
// If >= 0, we're the parent, so just exit
|
||||||
if exitStatus >= 0 {
|
if exitStatus >= 0 {
|
||||||
|
// Close the stdout writer so that our copy process can finish
|
||||||
|
outW.Close()
|
||||||
|
|
||||||
|
// Wait for the output copying to finish
|
||||||
|
<-doneCh
|
||||||
|
|
||||||
return exitStatus
|
return exitStatus
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,7 +183,9 @@ func cliConfigFile() (string, error) {
|
|||||||
// copyOutput uses output prefixes to determine whether data on stdout
|
// copyOutput uses output prefixes to determine whether data on stdout
|
||||||
// should go to stdout or stderr. This is due to panicwrap using stderr
|
// should go to stdout or stderr. This is due to panicwrap using stderr
|
||||||
// as the log and error channel.
|
// as the log and error channel.
|
||||||
func copyOutput(r io.Reader) {
|
func copyOutput(r io.Reader, doneCh chan<- struct{}) {
|
||||||
|
defer close(doneCh)
|
||||||
|
|
||||||
pr, err := prefixedio.NewReader(r)
|
pr, err := prefixedio.NewReader(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
@ -194,7 +204,20 @@ func copyOutput(r io.Reader) {
|
|||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
go io.Copy(os.Stderr, stderrR)
|
var wg sync.WaitGroup
|
||||||
go io.Copy(os.Stdout, stdoutR)
|
wg.Add(3)
|
||||||
go io.Copy(os.Stdout, defaultR)
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
io.Copy(os.Stderr, stderrR)
|
||||||
|
}()
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
io.Copy(os.Stdout, stdoutR)
|
||||||
|
}()
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
io.Copy(os.Stdout, defaultR)
|
||||||
|
}()
|
||||||
|
|
||||||
|
wg.Wait()
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user