Home | History | Annotate | Line # | Download | only in systat
keyboard.c revision 1.6
      1  1.6  sommerfe /*	$NetBSD: keyboard.c,v 1.6 1999/08/02 02:01:57 sommerfeld Exp $	*/
      2  1.2       jtc 
      3  1.1       jtc /*-
      4  1.1       jtc  * Copyright (c) 1980, 1992, 1993
      5  1.1       jtc  *	The Regents of the University of California.  All rights reserved.
      6  1.1       jtc  *
      7  1.1       jtc  * Redistribution and use in source and binary forms, with or without
      8  1.1       jtc  * modification, are permitted provided that the following conditions
      9  1.1       jtc  * are met:
     10  1.1       jtc  * 1. Redistributions of source code must retain the above copyright
     11  1.1       jtc  *    notice, this list of conditions and the following disclaimer.
     12  1.1       jtc  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1       jtc  *    notice, this list of conditions and the following disclaimer in the
     14  1.1       jtc  *    documentation and/or other materials provided with the distribution.
     15  1.1       jtc  * 3. All advertising materials mentioning features or use of this software
     16  1.1       jtc  *    must display the following acknowledgement:
     17  1.1       jtc  *	This product includes software developed by the University of
     18  1.1       jtc  *	California, Berkeley and its contributors.
     19  1.1       jtc  * 4. Neither the name of the University nor the names of its contributors
     20  1.1       jtc  *    may be used to endorse or promote products derived from this software
     21  1.1       jtc  *    without specific prior written permission.
     22  1.1       jtc  *
     23  1.1       jtc  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24  1.1       jtc  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25  1.1       jtc  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26  1.1       jtc  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27  1.1       jtc  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28  1.1       jtc  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29  1.1       jtc  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30  1.1       jtc  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31  1.1       jtc  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32  1.1       jtc  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33  1.1       jtc  * SUCH DAMAGE.
     34  1.1       jtc  */
     35  1.1       jtc 
     36  1.4       mrg #include <sys/cdefs.h>
     37  1.1       jtc #ifndef lint
     38  1.2       jtc #if 0
     39  1.1       jtc static char sccsid[] = "@(#)keyboard.c	8.1 (Berkeley) 6/6/93";
     40  1.2       jtc #endif
     41  1.6  sommerfe __RCSID("$NetBSD: keyboard.c,v 1.6 1999/08/02 02:01:57 sommerfeld Exp $");
     42  1.1       jtc #endif /* not lint */
     43  1.1       jtc 
     44  1.5       mrg #include <sys/types.h>
     45  1.5       mrg 
     46  1.1       jtc #include <ctype.h>
     47  1.5       mrg #include <curses.h>
     48  1.1       jtc #include <signal.h>
     49  1.1       jtc #include <termios.h>
     50  1.5       mrg #include <stdlib.h>
     51  1.1       jtc 
     52  1.1       jtc #include "systat.h"
     53  1.1       jtc #include "extern.h"
     54  1.1       jtc 
     55  1.1       jtc int
     56  1.1       jtc keyboard()
     57  1.1       jtc {
     58  1.6  sommerfe 	char ch, rch, *line;
     59  1.6  sommerfe 	int i, linesz;
     60  1.3    scottr 	sigset_t set;
     61  1.1       jtc 
     62  1.3    scottr 	sigemptyset(&set);
     63  1.3    scottr 	sigaddset(&set, SIGALRM);
     64  1.3    scottr 
     65  1.5       mrg 	linesz = COLS - 2;		/* XXX does not get updated on SIGWINCH */
     66  1.5       mrg 	line = malloc(linesz);
     67  1.5       mrg 	if (line == NULL) {
     68  1.5       mrg 		error("malloc");
     69  1.5       mrg 		exit(1);
     70  1.5       mrg 	}
     71  1.5       mrg 
     72  1.3    scottr 	for (;;) {
     73  1.3    scottr 		col = 0;
     74  1.3    scottr 		move(CMDLINE, 0);
     75  1.3    scottr 		do {
     76  1.3    scottr 			refresh();
     77  1.3    scottr 			ch = getch() & 0177;
     78  1.3    scottr 			if (ch == 0177 && ferror(stdin)) {
     79  1.3    scottr 				clearerr(stdin);
     80  1.3    scottr 				continue;
     81  1.3    scottr 			}
     82  1.6  sommerfe 			rch = ch;
     83  1.3    scottr 			if (ch >= 'A' && ch <= 'Z')
     84  1.3    scottr 				ch += 'a' - 'A';
     85  1.3    scottr 			if (col == 0) {
     86  1.3    scottr 				if (ch == CTRL('l')) {
     87  1.3    scottr 					sigprocmask(SIG_BLOCK, &set, NULL);
     88  1.1       jtc 					wrefresh(curscr);
     89  1.3    scottr 					sigprocmask(SIG_UNBLOCK, &set, NULL);
     90  1.3    scottr 					continue;
     91  1.3    scottr 				}
     92  1.1       jtc 				if (ch == CTRL('g')) {
     93  1.3    scottr 					sigprocmask(SIG_BLOCK, &set, NULL);
     94  1.1       jtc 					status();
     95  1.3    scottr 					sigprocmask(SIG_UNBLOCK, &set, NULL);
     96  1.1       jtc 					continue;
     97  1.1       jtc 				}
     98  1.3    scottr 				if (ch != ':')
     99  1.3    scottr 					continue;
    100  1.3    scottr 				move(CMDLINE, 0);
    101  1.3    scottr 				clrtoeol();
    102  1.3    scottr 			}
    103  1.3    scottr 			if (ch == erasechar() && col > 0) {
    104  1.3    scottr 				if (col == 1 && line[0] == ':')
    105  1.3    scottr 					continue;
    106  1.3    scottr 				col--;
    107  1.3    scottr 				goto doerase;
    108  1.3    scottr 			}
    109  1.3    scottr 			if (ch == CTRL('w') && col > 0) {
    110  1.3    scottr 				while (--col >= 0 && isspace(line[col]));
    111  1.3    scottr 				col++;
    112  1.3    scottr 				while (--col >= 0 && !isspace(line[col]))
    113  1.3    scottr 					if (col == 0 && line[0] == ':')
    114  1.3    scottr 						break;
    115  1.3    scottr 				col++;
    116  1.3    scottr 				goto doerase;
    117  1.3    scottr 			}
    118  1.3    scottr 			if (ch == killchar() && col > 0) {
    119  1.3    scottr 				if (line[0] == ':')
    120  1.5       mrg 					col = 1;
    121  1.5       mrg 				else
    122  1.5       mrg 					col = 0;
    123  1.3    scottr 		doerase:
    124  1.3    scottr 				move(CMDLINE, col);
    125  1.3    scottr 				clrtoeol();
    126  1.3    scottr 				continue;
    127  1.3    scottr 			}
    128  1.6  sommerfe 			if (isprint(rch) || ch == ' ') {
    129  1.5       mrg 				if (col < linesz) {
    130  1.6  sommerfe 					line[col] = rch;
    131  1.6  sommerfe 					mvaddch(CMDLINE, col, rch);
    132  1.5       mrg 					col++;
    133  1.5       mrg 				}
    134  1.3    scottr 			}
    135  1.3    scottr 		} while (col == 0 || (ch != '\r' && ch != '\n'));
    136  1.3    scottr 		line[col] = '\0';
    137  1.6  sommerfe 		/* pass commands as lowercase */
    138  1.6  sommerfe 		for (i = 1; i < col && line[i] != ' '; i++)
    139  1.6  sommerfe 		    if (line[i] >= 'A' && line[i] <= 'Z')
    140  1.6  sommerfe 			line[i] += 'a' - 'A';
    141  1.3    scottr 		sigprocmask(SIG_BLOCK, &set, NULL);
    142  1.3    scottr 		command(line + 1);
    143  1.3    scottr 		sigprocmask(SIG_UNBLOCK, &set, NULL);
    144  1.3    scottr 	}
    145  1.3    scottr 	/* NOTREACHED */
    146  1.1       jtc }
    147