summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLukas Fleischer <calcurse@cryptocrack.de>2012-11-28 21:42:54 +0100
committerLukas Fleischer <calcurse@cryptocrack.de>2012-11-28 21:49:02 +0100
commit8ae75f3ca723d4d7e449c18f1704147b229ac66c (patch)
treee8ba8f59bedbe6c2971223334b35182e34f03d16
parent7f16e1c1d30f56d796b1e7f2286c9ccfdd97061f (diff)
downloadcalcurse-8ae75f3ca723d4d7e449c18f1704147b229ac66c.zip
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>
-rw-r--r--src/calcurse.h2
-rw-r--r--src/sigs.c14
-rw-r--r--src/wins.c4
3 files changed, 20 insertions, 0 deletions
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();
}