aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Fox <pgf@brightstareng.com>2008-03-17 15:28:07 +0000
committerPaul Fox <pgf@brightstareng.com>2008-03-17 15:28:07 +0000
commit2724fa9d8a076f52c158627877d59894789b09a1 (patch)
tree7b4eece4fb93d44a56b0ef29d06e2bc4721b3f63
parentfb274df0797f58cda0b3b6809769707fe21e40e7 (diff)
downloadbusybox-2724fa9d8a076f52c158627877d59894789b09a1.tar.gz
remove alarm() calls which were functioning as a primitive
watchdog function, presumably to catch infinite loop bugs. (control-C can do the same thing, and the alarms were too short in any case.) also, switch to sigsetjmp/siglongjmp in order to allow repeated use of control-C -- otherwise it works once, then not again.
-rw-r--r--editors/vi.c20
1 files changed, 3 insertions, 17 deletions
diff --git a/editors/vi.c b/editors/vi.c
index c2d4457e9..22bd2fffa 100644
--- a/editors/vi.c
+++ b/editors/vi.c
@@ -201,7 +201,7 @@ struct globals {
#endif
/* a few references only */
#if ENABLE_FEATURE_VI_USE_SIGNALS
- jmp_buf restart; // catch_sig()
+ sigjmp_buf restart; // catch_sig()
#endif
struct termios term_orig, term_vi; // remember what the cooked mode was
#if ENABLE_FEATURE_VI_COLON
@@ -516,7 +516,7 @@ static void edit_file(char *fn)
catch_sig(0);
signal(SIGWINCH, winch_sig);
signal(SIGTSTP, suspend_sig);
- sig = setjmp(restart);
+ sig = sigsetjmp(restart, 1);
if (sig != 0) {
screenbegin = dot = text;
}
@@ -799,7 +799,6 @@ static void colon(char *buf)
else if (strncmp(cmd, "!", 1) == 0) { // run a cmd
int retcode;
// :!ls run the <cmd>
- alarm(0); // wait for input- no alarms
place_cursor(rows - 1, 0, FALSE); // go to Status line
clear_to_eol(); // clear the line
cookmode();
@@ -808,7 +807,6 @@ static void colon(char *buf)
printf("\nshell returned %i\n\n", retcode);
rawmode();
Hit_Return(); // let user see results
- alarm(3); // done waiting for input
}
#endif
else if (strncmp(cmd, "=", i) == 0) { // where is the address
@@ -2153,7 +2151,7 @@ static void catch_sig(int sig)
{
signal(SIGINT, catch_sig);
if (sig)
- longjmp(restart, sig);
+ siglongjmp(restart, sig);
}
#endif /* FEATURE_VI_USE_SIGNALS */
@@ -2217,7 +2215,6 @@ static char readit(void) // read (maybe cursor) key from stdin
};
enum { ESCCMDS_COUNT = ARRAY_SIZE(esccmds) };
- alarm(0); // turn alarm OFF while we wait for input
fflush(stdout);
n = chars_to_parse;
// get input from User- are there already input chars in Q?
@@ -2273,7 +2270,6 @@ static char readit(void) // read (maybe cursor) key from stdin
// remove key sequence from Q
chars_to_parse -= n;
memmove(readbuffer, readbuffer + n, sizeof(readbuffer) - n);
- alarm(3); // we are done waiting for input, turn alarm ON
return c;
}
@@ -3054,14 +3050,6 @@ static void do_cmd(char c)
case VI_K_PAGEUP: // Cursor Key Page Up
dot_scroll(rows - 2, -1);
break;
-#if ENABLE_FEATURE_VI_USE_SIGNALS
- case 0x03: // ctrl-C interrupt
- longjmp(restart, 1);
- break;
- case 26: // ctrl-Z suspend
- suspend_sig(SIGTSTP);
- break;
-#endif
case 4: // ctrl-D scroll down half screen
dot_scroll((rows - 2) / 2, 1);
break;
@@ -4037,7 +4025,6 @@ static void crash_test()
}
if (msg[0]) {
- alarm(0);
printf("\n\n%d: \'%c\' %s\n\n\n%s[Hit return to continue]%s",
totalcmds, last_input_char, msg, SOs, SOn);
fflush(stdout);
@@ -4045,7 +4032,6 @@ static void crash_test()
if (d[0] == '\n' || d[0] == '\r')
break;
}
- alarm(3);
}
tim = time(NULL);
if (tim >= (oldtim + 3)) {