Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/systat 1.) Clean up keystroke processing
details: https://anonhg.NetBSD.org/src/rev/9fa602b071ed
branches: trunk
changeset: 479749:9fa602b071ed
user: jwise <jwise%NetBSD.org@localhost>
date: Mon Dec 20 20:49:06 1999 +0000
description:
1.) Clean up keystroke processing
2.) Add the all-time most requested feature: hitting space or CR while
not in command mode now causes an instant refresh
diffstat:
usr.bin/systat/keyboard.c | 60 +++++++++++++++++++++++++---------------------
1 files changed, 32 insertions(+), 28 deletions(-)
diffs (125 lines):
diff -r dfd56fa2d485 -r 9fa602b071ed usr.bin/systat/keyboard.c
--- a/usr.bin/systat/keyboard.c Mon Dec 20 20:45:56 1999 +0000
+++ b/usr.bin/systat/keyboard.c Mon Dec 20 20:49:06 1999 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: keyboard.c,v 1.7 1999/11/15 06:16:56 simonb Exp $ */
+/* $NetBSD: keyboard.c,v 1.8 1999/12/20 20:49:06 jwise Exp $ */
/*-
* Copyright (c) 1980, 1992, 1993
@@ -38,7 +38,7 @@
#if 0
static char sccsid[] = "@(#)keyboard.c 8.1 (Berkeley) 6/6/93";
#endif
-__RCSID("$NetBSD: keyboard.c,v 1.7 1999/11/15 06:16:56 simonb Exp $");
+__RCSID("$NetBSD: keyboard.c,v 1.8 1999/12/20 20:49:06 jwise Exp $");
#endif /* not lint */
#include <sys/types.h>
@@ -72,7 +72,8 @@
for (;;) {
col = 0;
move(CMDLINE, 0);
- do {
+
+ while (col == 0 || (ch != '\r' && ch != '\n')) {
refresh();
ch = getch() & 0177;
if (ch == 0177 && ferror(stdin)) {
@@ -80,33 +81,40 @@
continue;
}
rch = ch;
- if (ch >= 'A' && ch <= 'Z')
- ch += 'a' - 'A';
+ ch = tolower(ch);
if (col == 0) {
- if (ch == CTRL('l')) {
+ switch(ch) {
+ case '\n':
+ case '\r':
+ case ' ':
+ display(0);
+ break;
+ case CTRL('l'):
sigprocmask(SIG_BLOCK, &set, NULL);
wrefresh(curscr);
sigprocmask(SIG_UNBLOCK, &set, NULL);
- continue;
- }
- if (ch == CTRL('g')) {
+ break;
+ case CTRL('g'):
sigprocmask(SIG_BLOCK, &set, NULL);
status();
sigprocmask(SIG_UNBLOCK, &set, NULL);
- continue;
- }
- if (ch == '?' || ch == 'h') {
+ break;
+ case '?':
+ case 'h':
command("help");
move(CMDLINE, 0);
- continue;
+ break;
+ case ':':
+ move(CMDLINE, 0);
+ clrtoeol();
+ addch(':');
+ col++;
+ break;
}
- if (ch != ':')
- continue;
- move(CMDLINE, 0);
- clrtoeol();
+ continue;
}
if (ch == erasechar() && col > 0) {
- if (col == 1 && line[0] == ':')
+ if (col == 1)
continue;
col--;
goto doerase;
@@ -115,34 +123,30 @@
while (--col >= 0 && isspace(line[col]));
col++;
while (--col >= 0 && !isspace(line[col]))
- if (col == 0 && line[0] == ':')
+ if (col == 0)
break;
col++;
goto doerase;
}
if (ch == killchar() && col > 0) {
- if (line[0] == ':')
- col = 1;
- else
- col = 0;
+ col = 1;
doerase:
move(CMDLINE, col);
clrtoeol();
continue;
}
- if (isprint(rch) || ch == ' ') {
+ if (isprint(rch) || rch == ' ') {
if (col < linesz) {
line[col] = rch;
mvaddch(CMDLINE, col, rch);
col++;
}
}
- } while (col == 0 || (ch != '\r' && ch != '\n'));
+ }
line[col] = '\0';
/* pass commands as lowercase */
- for (i = 1; i < col && line[i] != ' '; i++)
- if (line[i] >= 'A' && line[i] <= 'Z')
- line[i] += 'a' - 'A';
+ for (i = 1; i < col ; i++)
+ line[i] = tolower(line[i]);
sigprocmask(SIG_BLOCK, &set, NULL);
command(line + 1);
sigprocmask(SIG_UNBLOCK, &set, NULL);
Home |
Main Index |
Thread Index |
Old Index