|
|
@ -1,9 +1,7 @@ |
|
|
|
package main |
|
|
|
|
|
|
|
import ( |
|
|
|
"bufio" |
|
|
|
"fmt" |
|
|
|
"io" |
|
|
|
"io/ioutil" |
|
|
|
"os" |
|
|
|
"os/exec" |
|
|
@ -179,27 +177,20 @@ func (p Plugin) Exec() error { |
|
|
|
}).Fatal("Failed to execute a command") |
|
|
|
} |
|
|
|
} else { |
|
|
|
// open the out file for writing
|
|
|
|
outfile, err := os.Create(c.Ofile) |
|
|
|
if err != nil { |
|
|
|
panic(err) |
|
|
|
} |
|
|
|
defer outfile.Close() |
|
|
|
|
|
|
|
stdoutPipe, err := c.Tfcmd.StdoutPipe() |
|
|
|
if err != nil { |
|
|
|
panic(err) |
|
|
|
} |
|
|
|
|
|
|
|
writer := bufio.NewWriter(outfile) |
|
|
|
logrus.WithFields(logrus.Fields{ |
|
|
|
"file": c.Ofile, |
|
|
|
"command": strings.Join(c.Tfcmd.Args, " "), |
|
|
|
}).Info("Command") |
|
|
|
|
|
|
|
err = c.Tfcmd.Start() |
|
|
|
out, err := c.Tfcmd.CombinedOutput() |
|
|
|
if err != nil { |
|
|
|
panic(err) |
|
|
|
logrus.WithFields(logrus.Fields{ |
|
|
|
"command": strings.Join(c.Tfcmd.Args, " "), |
|
|
|
"error": err, |
|
|
|
}).Fatal("Failed to execute a command") |
|
|
|
} |
|
|
|
|
|
|
|
go io.Copy(writer, stdoutPipe) |
|
|
|
c.Tfcmd.Wait() |
|
|
|
f, _ := os.Create(c.Ofile) |
|
|
|
f.Write(out) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|