aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Palka <patrick@parcs.ath.cx>2014-08-30 15:33:08 -0400
committerJoel Brobecker <brobecker@adacore.com>2014-11-23 14:12:05 +0400
commita344fc094daa257557786eb2ce871debf38456ba (patch)
treeeadc4c44661c7031f68a9ce117435c9dfbc17991
parentd64e57faa89ba4de0ebacdc30fbee5d19310950c (diff)
downloadgdb-a344fc094daa257557786eb2ce871debf38456ba.zip
gdb-a344fc094daa257557786eb2ce871debf38456ba.tar.gz
gdb-a344fc094daa257557786eb2ce871debf38456ba.tar.bz2
Specify SA_RESTART when registering the SIGWINCH signal handler
SA_RESTART allows system calls to be restarted across a signal handler. By specifying this flag we fix the issue where if the user is being prompted to answer yes or no, and the terminal gets resized in the meantime, the prompt will think that the user sent an EOF and so it will take the default action for that prompt (in the case of the quit prompt, it will quit GDB). gdb/ChangeLog: * tui/tui-win.c (tui_initialize_win): Specify SA_RESTART when registering the signal handler.
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/tui/tui-win.c3
2 files changed, 8 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 326a0d6..45435fc 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,10 @@
2014-11-23 Patrick Palka <patrick@parcs.ath.cx>
+ * tui/tui-win.c (tui_initialize_win): Specify SA_RESTART when
+ registering the signal handler.
+
+2014-11-23 Patrick Palka <patrick@parcs.ath.cx>
+
* event-top.h (call_stdin_event_handler_again_p): Declare.
* event-top.c (call_stdin_event_handler_again_p): Define.
(stdin_event_handler): Use it.
diff --git a/gdb/tui/tui-win.c b/gdb/tui/tui-win.c
index d17a1e4..4488da8 100644
--- a/gdb/tui/tui-win.c
+++ b/gdb/tui/tui-win.c
@@ -834,6 +834,9 @@ tui_initialize_win (void)
memset (&old_winch, 0, sizeof (old_winch));
old_winch.sa_handler = &tui_sigwinch_handler;
+#ifdef SA_RESTART
+ old_winch.sa_flags = SA_RESTART;
+#endif
sigaction (SIGWINCH, &old_winch, NULL);
#else
signal (SIGWINCH, &tui_sigwinch_handler);