From 5ebdd3fe6e7e038ed0c8394bfee4f5ccb8510066 Mon Sep 17 00:00:00 2001
From: Benno Schulenberg <bensberg@telfort.nl>
Date: Fri, 23 Jun 2017 09:00:15 +0200
Subject: [PATCH] tweaks: reduce the scope of three variables, and rename them
 besides

---
 src/nano.c | 26 +++++++++++++-------------
 1 file changed, 13 insertions(+), 13 deletions(-)

diff --git a/src/nano.c b/src/nano.c
index 1d8991e2..56bcbe71 100644
--- a/src/nano.c
+++ b/src/nano.c
@@ -1100,10 +1100,6 @@ void do_cancel(void)
     ;
 }
 
-static struct sigaction pager_oldaction, pager_newaction;
-	/* Original and temporary handlers for SIGINT. */
-static bool pager_sig_failed = FALSE;
-	/* Did sigaction() fail without changing the signal handlers? */
 static bool pager_input_aborted = FALSE;
 	/* Did someone invoke the pager and abort it via ^C? */
 
@@ -1116,13 +1112,17 @@ RETSIGTYPE cancel_stdin_pager(int signal)
 /* Read whatever comes from standard input into a new buffer. */
 bool scoop_stdin(void)
 {
+    struct sigaction oldaction, newaction;
+	/* Original and temporary handlers for SIGINT. */
+    bool setup_failed = FALSE;
+	/* Whether setting up the SIGINT handler failed. */
     FILE *stream;
     int thetty;
 
+    /* Exit from curses mode and put the terminal into its original state. */
     endwin();
+    tcsetattr(0, TCSANOW, &oldterm);
 
-    if (!pager_input_aborted)
-	tcsetattr(0, TCSANOW, &oldterm);
     fprintf(stderr, _("Reading from stdin, ^C to abort\n"));
 
 #ifndef NANO_TINY
@@ -1131,14 +1131,14 @@ bool scoop_stdin(void)
     enable_signals();
 #endif
 
-    /* Set things up so that SIGINT will cancel the new process. */
-    if (sigaction(SIGINT, NULL, &pager_newaction) == -1) {
-	pager_sig_failed = TRUE;
+    /* Set things up so that SIGINT will cancel the reading. */
+    if (sigaction(SIGINT, NULL, &newaction) == -1) {
+	setup_failed = TRUE;
 	nperror("sigaction");
     } else {
-	pager_newaction.sa_handler = cancel_stdin_pager;
-	if (sigaction(SIGINT, &pager_newaction, &pager_oldaction) == -1) {
-	    pager_sig_failed = TRUE;
+	newaction.sa_handler = cancel_stdin_pager;
+	if (sigaction(SIGINT, &newaction, &oldaction) == -1) {
+	    setup_failed = TRUE;
 	    nperror("sigaction");
 	}
     }
@@ -1168,7 +1168,7 @@ bool scoop_stdin(void)
 
     if (!pager_input_aborted)
 	tcgetattr(0, &oldterm);
-    if (!pager_sig_failed && sigaction(SIGINT, &pager_oldaction, NULL) == -1)
+    if (!setup_failed && sigaction(SIGINT, &oldaction, NULL) == -1)
 	nperror("sigaction");
 
     terminal_init();
-- 
GitLab