2015-07-25 04:35:07 -04:00
|
|
|
// Package signal provides helper functions for dealing with signals across
|
|
|
|
// various operating systems.
|
2014-03-10 16:38:17 -04:00
|
|
|
package signal
|
2013-10-29 14:59:08 -04:00
|
|
|
|
|
|
|
import (
|
2015-08-04 16:51:48 -04:00
|
|
|
"fmt"
|
2013-10-29 14:59:08 -04:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
2015-08-04 16:51:48 -04:00
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"syscall"
|
2013-10-29 14:59:08 -04:00
|
|
|
)
|
|
|
|
|
2015-07-25 04:35:07 -04:00
|
|
|
// CatchAll catches all signals and relays them to the specified channel.
|
2014-03-10 16:50:16 -04:00
|
|
|
func CatchAll(sigc chan os.Signal) {
|
|
|
|
handledSigs := []os.Signal{}
|
2014-03-10 17:22:27 -04:00
|
|
|
for _, s := range SignalMap {
|
2014-03-10 16:50:16 -04:00
|
|
|
handledSigs = append(handledSigs, s)
|
|
|
|
}
|
|
|
|
signal.Notify(sigc, handledSigs...)
|
|
|
|
}
|
|
|
|
|
2015-07-25 04:35:07 -04:00
|
|
|
// StopCatch stops catching the signals and closes the specified channel.
|
2013-10-29 14:59:08 -04:00
|
|
|
func StopCatch(sigc chan os.Signal) {
|
|
|
|
signal.Stop(sigc)
|
|
|
|
close(sigc)
|
|
|
|
}
|
2015-08-04 16:51:48 -04:00
|
|
|
|
|
|
|
// ParseSignal translates a string to a valid syscall signal.
|
|
|
|
// It returns an error if the signal map doesn't include the given signal.
|
|
|
|
func ParseSignal(rawSignal string) (syscall.Signal, error) {
|
|
|
|
s, err := strconv.Atoi(rawSignal)
|
|
|
|
if err == nil {
|
|
|
|
if s == 0 {
|
|
|
|
return -1, fmt.Errorf("Invalid signal: %s", rawSignal)
|
|
|
|
}
|
|
|
|
return syscall.Signal(s), nil
|
|
|
|
}
|
|
|
|
signal, ok := SignalMap[strings.TrimPrefix(strings.ToUpper(rawSignal), "SIG")]
|
|
|
|
if !ok {
|
|
|
|
return -1, fmt.Errorf("Invalid signal: %s", rawSignal)
|
|
|
|
}
|
|
|
|
return signal, nil
|
|
|
|
}
|