From 8115fc04b13867f51d6a72466a6346ea690168e7 Mon Sep 17 00:00:00 2001 From: cgf Date: Wed, 5 Sep 2001 02:42:49 +0000 Subject: [PATCH] * exceptions.cc (ctrl_c_handler): Only send SIGINT when we have a controlling terminal and we are the head of the process group. --- winsup/cygwin/ChangeLog | 5 +++++ winsup/cygwin/exceptions.cc | 8 +++----- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 95d999fa97..1d60b7f861 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,8 @@ +Tue Sep 4 22:42:13 2001 Christopher Faylor + + * exceptions.cc (ctrl_c_handler): Only send SIGINT when we have a + controlling terminal and we are the head of the process group. + Tue Sep 4 16:48:14 2001 Christopher Faylor * thread.cc (InterlockedExchangePointer): Don't define if it already diff --git a/winsup/cygwin/exceptions.cc b/winsup/cygwin/exceptions.cc index 7a2061aa5a..cdeb112e5e 100644 --- a/winsup/cygwin/exceptions.cc +++ b/winsup/cygwin/exceptions.cc @@ -912,11 +912,8 @@ ctrl_c_handler (DWORD type) tty_min *t = cygwin_shared->tty.get_tty (myself->ctty); /* Ignore this if we're not the process group lead since it should be handled *by* the process group leader. */ - if (t->getpgid () && pid_exists (t->getpgid ()) && - (t->getpgid () != myself->pid || - (GetTickCount () - t->last_ctrl_c) < MIN_CTRL_C_SLOP)) - return TRUE; - else + if (myself->ctty != -1 && t->getpgid () == myself->pid && + (GetTickCount () - t->last_ctrl_c) >= MIN_CTRL_C_SLOP) /* Otherwise we just send a SIGINT to the process group and return TRUE (to indicate that we have handled the signal). At this point, type should be a CTRL_C_EVENT or CTRL_BREAK_EVENT. */ @@ -926,6 +923,7 @@ ctrl_c_handler (DWORD type) t->last_ctrl_c = GetTickCount (); return TRUE; } + return TRUE; } /* Set the signal mask for this process. -- 2.11.0