From 9a78857b316a54d060947e862422d563285ddb65 Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Tue, 5 May 2015 11:08:45 -0600 Subject: [PATCH] Startup/shutdown commands run in background with & --- config/setup/startupshutdown.go | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/config/setup/startupshutdown.go b/config/setup/startupshutdown.go index e34357760..65fe8b809 100644 --- a/config/setup/startupshutdown.go +++ b/config/setup/startupshutdown.go @@ -3,6 +3,7 @@ package setup import ( "os" "os/exec" + "strings" "github.com/mholt/caddy/middleware" ) @@ -20,11 +21,19 @@ func Shutdown(c *Controller) (middleware.Middleware, error) { // to the list of callback functions passed in by reference. func registerCallback(c *Controller, list *[]func() error) error { for c.Next() { - if !c.NextArg() { + args := c.RemainingArgs() + if len(args) == 0 { return c.ArgErr() } - command, args, err := middleware.SplitCommandAndArgs(c.Val()) + nonblock := false + if len(args) > 1 && args[len(args)-1] == "&" { + // Run command in background; non-blocking + nonblock = true + args = args[:len(args)-1] + } + + command, args, err := middleware.SplitCommandAndArgs(strings.Join(args, " ")) if err != nil { return c.Err(err.Error()) } @@ -33,7 +42,12 @@ func registerCallback(c *Controller, list *[]func() error) error { cmd := exec.Command(command, args...) cmd.Stdout = os.Stdout cmd.Stderr = os.Stderr - return cmd.Run() + + if nonblock { + return cmd.Start() + } else { + return cmd.Run() + } } *list = append(*list, fn)