Home | History | Annotate | Line # | Download | only in systat
keyboard.c revision 1.5
      1  1.5     mrg /*	$NetBSD: keyboard.c,v 1.5 1998/07/12 05:59:00 mrg 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.5     mrg __RCSID("$NetBSD: keyboard.c,v 1.5 1998/07/12 05:59:00 mrg 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.5     mrg 	char ch, *line;
     59  1.5     mrg 	int 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.3  scottr 			if (ch >= 'A' && ch <= 'Z')
     83  1.3  scottr 				ch += 'a' - 'A';
     84  1.3  scottr 			if (col == 0) {
     85  1.3  scottr 				if (ch == CTRL('l')) {
     86  1.3  scottr 					sigprocmask(SIG_BLOCK, &set, NULL);
     87  1.1     jtc 					wrefresh(curscr);
     88  1.3  scottr 					sigprocmask(SIG_UNBLOCK, &set, NULL);
     89  1.3  scottr 					continue;
     90  1.3  scottr 				}
     91  1.1     jtc 				if (ch == CTRL('g')) {
     92  1.3  scottr 					sigprocmask(SIG_BLOCK, &set, NULL);
     93  1.1     jtc 					status();
     94  1.3  scottr 					sigprocmask(SIG_UNBLOCK, &set, NULL);
     95  1.1     jtc 					continue;
     96  1.1     jtc 				}
     97  1.3  scottr 				if (ch != ':')
     98  1.3  scottr 					continue;
     99  1.3  scottr 				move(CMDLINE, 0);
    100  1.3  scottr 				clrtoeol();
    101  1.3  scottr 			}
    102  1.3  scottr 			if (ch == erasechar() && col > 0) {
    103  1.3  scottr 				if (col == 1 && line[0] == ':')
    104  1.3  scottr 					continue;
    105  1.3  scottr 				col--;
    106  1.3  scottr 				goto doerase;
    107  1.3  scottr 			}
    108  1.3  scottr 			if (ch == CTRL('w') && col > 0) {
    109  1.3  scottr 				while (--col >= 0 && isspace(line[col]));
    110  1.3  scottr 				col++;
    111  1.3  scottr 				while (--col >= 0 && !isspace(line[col]))
    112  1.3  scottr 					if (col == 0 && line[0] == ':')
    113  1.3  scottr 						break;
    114  1.3  scottr 				col++;
    115  1.3  scottr 				goto doerase;
    116  1.3  scottr 			}
    117  1.3  scottr 			if (ch == killchar() && col > 0) {
    118  1.3  scottr 				if (line[0] == ':')
    119  1.5     mrg 					col = 1;
    120  1.5     mrg 				else
    121  1.5     mrg 					col = 0;
    122  1.3  scottr 		doerase:
    123  1.3  scottr 				move(CMDLINE, col);
    124  1.3  scottr 				clrtoeol();
    125  1.3  scottr 				continue;
    126  1.3  scottr 			}
    127  1.3  scottr 			if (isprint(ch) || ch == ' ') {
    128  1.5     mrg 				if (col < linesz) {
    129  1.5     mrg 					line[col] = ch;
    130  1.5     mrg 					mvaddch(CMDLINE, col, ch);
    131  1.5     mrg 					col++;
    132  1.5     mrg 				}
    133  1.3  scottr 			}
    134  1.3  scottr 		} while (col == 0 || (ch != '\r' && ch != '\n'));
    135  1.3  scottr 		line[col] = '\0';
    136  1.3  scottr 		sigprocmask(SIG_BLOCK, &set, NULL);
    137  1.3  scottr 		command(line + 1);
    138  1.3  scottr 		sigprocmask(SIG_UNBLOCK, &set, NULL);
    139  1.3  scottr 	}
    140  1.3  scottr 	/* NOTREACHED */
    141  1.1     jtc }
    142