diff options
author | openshift-ci[bot] <75433959+openshift-ci[bot]@users.noreply.github.com> | 2022-06-27 15:58:34 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-06-27 15:58:34 +0000 |
commit | 465c54829e46ca9724bd882756fba89bfaff965d (patch) | |
tree | 348c63a38955b9a517e073d9ee784737329d6ca7 /pkg/signal/signal_common.go | |
parent | 088665d2cfd488004f34dbd0804c3cd00bf94ca4 (diff) | |
parent | 66c62eb96816d7eb021da22d439838510d61f916 (diff) | |
download | podman-465c54829e46ca9724bd882756fba89bfaff965d.tar.gz podman-465c54829e46ca9724bd882756fba89bfaff965d.tar.bz2 podman-465c54829e46ca9724bd882756fba89bfaff965d.zip |
Merge pull request #14733 from dfr/unix-signal
Implement CatchAll and StopCatch in signal_unix.go
Diffstat (limited to 'pkg/signal/signal_common.go')
-rw-r--r-- | pkg/signal/signal_common.go | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/pkg/signal/signal_common.go b/pkg/signal/signal_common.go index fe5a76dae..fc1ecc04d 100644 --- a/pkg/signal/signal_common.go +++ b/pkg/signal/signal_common.go @@ -2,6 +2,8 @@ package signal import ( "fmt" + "os" + "os/signal" "strconv" "strings" "syscall" @@ -39,3 +41,18 @@ func ParseSignalNameOrNumber(rawSignal string) (syscall.Signal, error) { } return -1, fmt.Errorf("invalid signal: %s", basename) } + +// CatchAll catches all signals and relays them to the specified channel. +func CatchAll(sigc chan os.Signal) { + handledSigs := make([]os.Signal, 0, len(SignalMap)) + for _, s := range SignalMap { + handledSigs = append(handledSigs, s) + } + signal.Notify(sigc, handledSigs...) +} + +// StopCatch stops catching the signals and closes the specified channel. +func StopCatch(sigc chan os.Signal) { + signal.Stop(sigc) + close(sigc) +} |