cmd/utils: print errors only once if stdout and stderr are the same file

This commit is contained in:
Felix Lange 2015-05-27 15:48:07 +02:00
parent 74706a0f02
commit 705beb4c25

View File

@ -125,10 +125,17 @@ func initDataDir(Datadir string) {
} }
} }
// Fatalf formats a message to standard output and exits the program. // Fatalf formats a message to standard error and exits the program.
// The message is also printed to standard output if standard error
// is redirected to a different file.
func Fatalf(format string, args ...interface{}) { func Fatalf(format string, args ...interface{}) {
fmt.Fprintf(os.Stderr, "Fatal: "+format+"\n", args...) w := io.MultiWriter(os.Stdout, os.Stderr)
fmt.Fprintf(os.Stdout, "Fatal: "+format+"\n", args...) outf, _ := os.Stdout.Stat()
errf, _ := os.Stderr.Stat()
if outf != nil && errf != nil && os.SameFile(outf, errf) {
w = os.Stderr
}
fmt.Fprintf(w, "Fatal: "+format+"\n", args...)
logger.Flush() logger.Flush()
os.Exit(1) os.Exit(1)
} }