Skip to content

Instantly share code, notes, and snippets.

@yozel
Created September 8, 2022 23:44
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save yozel/bef38a9554df2fdb071da46379cc01b6 to your computer and use it in GitHub Desktop.
Save yozel/bef38a9554df2fdb071da46379cc01b6 to your computer and use it in GitHub Desktop.
wrapper
package main
import (
"flag"
"io"
"log"
"os"
"os/exec"
"os/signal"
)
func main() {
logPath := flag.String("log", "", "path to log file")
flag.Parse()
if *logPath == "" {
log.Fatal("log path is required")
}
args := flag.Args()
process := exec.Command(args[0], args[1:]...)
process.Stdin = os.Stdin
process.Stdout = os.Stdout
process.Stderr = os.Stderr
process.Env = os.Environ()
logFile, err := os.OpenFile(*logPath, os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0644)
if err != nil {
log.Fatalf("failed to open log file: %v", err)
}
defer logFile.Close()
process.Stdout = io.MultiWriter(process.Stdout, logFile)
process.Stderr = io.MultiWriter(process.Stderr, logFile)
sigs := make(chan os.Signal, 1)
signal.Notify(sigs)
go func() {
process.Process.Signal(<-sigs)
}()
err = process.Run()
if err != nil && err.(*exec.ExitError) == nil {
log.Fatalf("failed to run command: %v", err)
}
os.Exit(process.ProcessState.ExitCode())
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment