packer/plugin: flush os.Stderr whenever a plugin ends

This commit is contained in:
Mitchell Hashimoto 2013-07-30 10:48:59 -07:00
parent ce0322662d
commit 8c341b0c78
1 changed files with 9 additions and 0 deletions

View File

@ -244,9 +244,18 @@ func (c *Client) Start() (address string, err error) {
// Start goroutine to wait for process to exit // Start goroutine to wait for process to exit
go func() { go func() {
// Make sure we close the write end of our stderr listener so
// that the log goroutine ends properly.
defer stderr_w.Close() defer stderr_w.Close()
// Wait for the command to end.
cmd.Wait() cmd.Wait()
// Log and make sure to flush the logs write away
log.Printf("%s: plugin process exited\n", cmd.Path) log.Printf("%s: plugin process exited\n", cmd.Path)
os.Stderr.Sync()
// Mark that we exited
c.exited = true c.exited = true
}() }()