1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00

Merge pull request #25415 from avaid96/exitret

added functionality to interrupt the terminal when it is waiting for …
This commit is contained in:
Sebastiaan van Stijn 2016-08-09 16:47:54 +02:00 committed by GitHub
commit 91853e44ae

View file

@ -6,6 +6,7 @@ package term
import ( import (
"errors" "errors"
"fmt"
"io" "io"
"os" "os"
"os/signal" "os/signal"
@ -109,9 +110,14 @@ func SetRawTerminalOutput(fd uintptr) (*State, error) {
func handleInterrupt(fd uintptr, state *State) { func handleInterrupt(fd uintptr, state *State) {
sigchan := make(chan os.Signal, 1) sigchan := make(chan os.Signal, 1)
signal.Notify(sigchan, os.Interrupt) signal.Notify(sigchan, os.Interrupt)
go func() { go func() {
_ = <-sigchan for range sigchan {
RestoreTerminal(fd, state) // quit cleanly and the new terminal item is on a new line
fmt.Println()
signal.Stop(sigchan)
close(sigchan)
RestoreTerminal(fd, state)
os.Exit(1)
}
}() }()
} }