From 8ae75f3ca723d4d7e449c18f1704147b229ac66c Mon Sep 17 00:00:00 2001
From: Lukas Fleischer <calcurse@cryptocrack.de>
Date: Wed, 28 Nov 2012 21:42:54 +0100
Subject: Ignore signals during command execution

Disable signal handlers in wins_prepare_external() and reactivate them
in wins_unprepare_external().

Before, it was possible that resizing the window during editor/pager
mode resulted in the calcurse main screen appearing on top.

Addresses BUG#9.

Signed-off-by: Lukas Fleischer <calcurse@cryptocrack.de>
---
 src/calcurse.h |  2 ++
 src/sigs.c     | 14 ++++++++++++++
 src/wins.c     |  4 ++++
 3 files changed, 20 insertions(+)

(limited to 'src')

diff --git a/src/calcurse.h b/src/calcurse.h
index d7b5093..2992db8 100644
--- a/src/calcurse.h
+++ b/src/calcurse.h
@@ -883,6 +883,8 @@ void recur_apoint_paste_item(void);
 /* sigs.c */
 void sigs_init(void);
 unsigned sigs_set_hdlr(int, void (*)(int));
+void sigs_ignore(void);
+void sigs_unignore(void);
 
 /* todo.c */
 extern llist_t todolist;
diff --git a/src/sigs.c b/src/sigs.c
index 4cc01bf..77ef6b8 100644
--- a/src/sigs.c
+++ b/src/sigs.c
@@ -108,3 +108,17 @@ void sigs_init()
       || !sigs_set_hdlr(SIGINT, SIG_IGN))
     exit_calcurse(1);
 }
+
+/* Ignore SIGWINCH and SIGTERM signals. */
+void sigs_ignore(void)
+{
+  sigs_set_hdlr(SIGWINCH, SIG_IGN);
+  sigs_set_hdlr(SIGTERM, SIG_IGN);
+}
+
+/* No longer ignore SIGWINCH and SIGTERM signals. */
+void sigs_unignore(void)
+{
+  sigs_set_hdlr(SIGWINCH, generic_hdlr);
+  sigs_set_hdlr(SIGTERM, generic_hdlr);
+}
diff --git a/src/wins.c b/src/wins.c
index 249610c..ea7fd9f 100644
--- a/src/wins.c
+++ b/src/wins.c
@@ -591,16 +591,20 @@ void wins_prepare_external(void)
   clear();
   wins_refresh();
   endwin();
+  sigs_ignore();
 }
 
 /* Restore windows when returning from an external command. */
 void wins_unprepare_external(void)
 {
+  sigs_unignore();
   reset_prog_mode();
   clearok(curscr, TRUE);
   curs_set(0);
   ui_mode = UI_CURSES;
   wins_refresh();
+  wins_reinit();
+  wins_update(FLAG_ALL);
   if (notify_bar())
     notify_start_main_thread();
 }
-- 
cgit v1.2.3-70-g09d2