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
1 changed files with 9 additions and 3 deletions

View File

@ -6,6 +6,7 @@ package term
import (
"errors"
"fmt"
"io"
"os"
"os/signal"
@ -109,9 +110,14 @@ func SetRawTerminalOutput(fd uintptr) (*State, error) {
func handleInterrupt(fd uintptr, state *State) {
sigchan := make(chan os.Signal, 1)
signal.Notify(sigchan, os.Interrupt)
go func() {
_ = <-sigchan
RestoreTerminal(fd, state)
for range sigchan {
// 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)
}
}()
}