2022-06-11 21:32:06 -03:00
|
|
|
package task
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"github.com/go-task/task/v3/internal/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NOTE(@andreynering): This function intercepts SIGINT and SIGTERM signals
|
2022-08-17 19:37:58 +02:00
|
|
|
// so the Task process is not killed immediately and processes running have
|
2022-06-11 21:32:06 -03:00
|
|
|
// time to do cleanup work.
|
|
|
|
func (e *Executor) InterceptInterruptSignals() {
|
|
|
|
ch := make(chan os.Signal, 3)
|
|
|
|
signal.Notify(ch, os.Interrupt, syscall.SIGTERM)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for i := 1; i <= 3; i++ {
|
|
|
|
sig := <-ch
|
|
|
|
|
|
|
|
if i < 3 {
|
2023-04-27 01:20:06 +01:00
|
|
|
e.Logger.Outf(logger.Yellow, "task: Signal received: %q\n", sig)
|
2022-06-11 21:32:06 -03:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2023-04-27 01:20:06 +01:00
|
|
|
e.Logger.Errf(logger.Red, "task: Signal received for the third time: %q. Forcing shutdown\n", sig)
|
2022-06-11 21:32:06 -03:00
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|