Home | History | Annotate | Line # | Download | only in msgc
msg_sys.def revision 1.7
      1  1.7    cgd /*	$NetBSD: msg_sys.def,v 1.7 1999/06/23 09:19:33 cgd Exp $	*/
      2  1.1   phil 
      3  1.1   phil /*
      4  1.1   phil  * Copyright 1997 Piermont Information Systems Inc.
      5  1.1   phil  * All rights reserved.
      6  1.1   phil  *
      7  1.1   phil  * Written by Philip A. Nelson for Piermont Information Systems Inc.
      8  1.1   phil  *
      9  1.1   phil  * Redistribution and use in source and binary forms, with or without
     10  1.1   phil  * modification, are permitted provided that the following conditions
     11  1.1   phil  * are met:
     12  1.1   phil  * 1. Redistributions of source code must retain the above copyright
     13  1.1   phil  *    notice, this list of conditions and the following disclaimer.
     14  1.1   phil  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1   phil  *    notice, this list of conditions and the following disclaimer in the
     16  1.1   phil  *    documentation and/or other materials provided with the distribution.
     17  1.1   phil  * 3. All advertising materials mentioning features or use of this software
     18  1.1   phil  *    must display the following acknowledgement:
     19  1.1   phil  *      This product includes software develooped for the NetBSD Project by
     20  1.1   phil  *      Piermont Information Systems Inc.
     21  1.1   phil  * 4. The name of Piermont Information Systems Inc. may not be used to endorse
     22  1.1   phil  *    or promote products derived from this software without specific prior
     23  1.1   phil  *    written permission.
     24  1.1   phil  *
     25  1.1   phil  * THIS SOFTWARE IS PROVIDED BY PIERMONT INFORMATION SYSTEMS INC. ``AS IS''
     26  1.1   phil  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     27  1.1   phil  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     28  1.1   phil  * ARE DISCLAIMED. IN NO EVENT SHALL PIERMONT INFORMATION SYSTEMS INC. BE
     29  1.1   phil  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     30  1.1   phil  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     31  1.1   phil  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     32  1.1   phil  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     33  1.1   phil  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     34  1.1   phil  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
     35  1.1   phil  * THE POSSIBILITY OF SUCH DAMAGE.
     36  1.1   phil  *
     37  1.1   phil  */
     38  1.1   phil 
     39  1.1   phil static WINDOW *msg_win = NULL;
     40  1.6    cgd static char *cbuffer;
     41  1.6    cgd static size_t cbuffersize;
     42  1.1   phil static int do_echo = 1;
     43  1.1   phil 
     44  1.7    cgd 
     45  1.1   phil /* Routines */
     46  1.1   phil 
     47  1.2  veego void msg_beep (void)
     48  1.1   phil {
     49  1.1   phil 	fprintf (stderr, "\a");
     50  1.1   phil }
     51  1.1   phil 
     52  1.6    cgd int msg_window(WINDOW *window)
     53  1.1   phil {
     54  1.6    cgd 	size_t ncbuffersize;
     55  1.6    cgd 	char *ncbuffer;
     56  1.6    cgd 
     57  1.1   phil 	msg_win = window;
     58  1.6    cgd 
     59  1.6    cgd 	ncbuffersize = getmaxx(window) * getmaxy(window) + 1;
     60  1.6    cgd 	if (ncbuffersize > cbuffersize) {
     61  1.6    cgd 		ncbuffer = malloc(ncbuffersize);
     62  1.6    cgd 		if (ncbuffer == NULL)
     63  1.6    cgd 			return 1;
     64  1.6    cgd 		if (cbuffer != NULL)
     65  1.6    cgd 			free(cbuffer);
     66  1.6    cgd 		cbuffer = ncbuffer;
     67  1.6    cgd 		cbuffersize = ncbuffersize;
     68  1.6    cgd 	}
     69  1.6    cgd 	return 0;
     70  1.1   phil }
     71  1.1   phil 
     72  1.1   phil char *msg_string (int msg_no)
     73  1.1   phil {
     74  1.1   phil 	return msg_list[msg_no];
     75  1.1   phil }
     76  1.1   phil 
     77  1.1   phil void msg_clear(void)
     78  1.1   phil {
     79  1.1   phil 	wclear (msg_win);
     80  1.1   phil 	wrefresh (msg_win);
     81  1.1   phil }
     82  1.1   phil 
     83  1.1   phil void msg_standout(void)
     84  1.1   phil {
     85  1.1   phil 	wstandout(msg_win);
     86  1.1   phil }
     87  1.1   phil 
     88  1.1   phil void msg_standend(void)
     89  1.1   phil {
     90  1.1   phil 	wstandend(msg_win);
     91  1.1   phil }
     92  1.1   phil 
     93  1.1   phil int msg_vprintf (char *fmt, va_list ap)
     94  1.1   phil {
     95  1.1   phil 	int ret;
     96  1.1   phil 
     97  1.6    cgd 	ret = vsnprintf (cbuffer, cbuffersize, fmt, ap);
     98  1.1   phil 	waddstr (msg_win, cbuffer);
     99  1.1   phil 	wrefresh (msg_win);
    100  1.1   phil 	return ret;
    101  1.1   phil }
    102  1.1   phil 
    103  1.1   phil void msg_display(int msg_no, ...)
    104  1.1   phil {
    105  1.1   phil 	va_list ap;
    106  1.1   phil 
    107  1.7    cgd 	msg_clear();
    108  1.7    cgd 
    109  1.1   phil 	va_start(ap, msg_no);
    110  1.1   phil 	(void)msg_vprintf (msg_list[msg_no], ap);
    111  1.1   phil 	va_end(ap);
    112  1.1   phil }
    113  1.1   phil 
    114  1.1   phil void msg_display_add(int msg_no, ...)
    115  1.1   phil {
    116  1.1   phil 	va_list ap;
    117  1.1   phil 
    118  1.1   phil 	va_start (ap, msg_no);
    119  1.1   phil 	(void)msg_vprintf (msg_list[msg_no], ap);
    120  1.1   phil 	va_end (ap);
    121  1.1   phil }
    122  1.1   phil 
    123  1.1   phil int msg_printf (char *fmt, ...)
    124  1.1   phil {
    125  1.1   phil 	va_list ap;
    126  1.1   phil 	int  res;
    127  1.1   phil 
    128  1.7    cgd 	msg_clear();
    129  1.7    cgd 
    130  1.1   phil 	va_start (ap, fmt);
    131  1.1   phil 	res = msg_vprintf (fmt, ap);
    132  1.1   phil 	va_end (ap);
    133  1.1   phil 	return res;
    134  1.1   phil }
    135  1.1   phil 
    136  1.1   phil int msg_printf_add (char *fmt, ...)
    137  1.1   phil {
    138  1.1   phil 	va_list ap;
    139  1.1   phil 	int  res;
    140  1.1   phil 
    141  1.1   phil 	va_start (ap, fmt);
    142  1.1   phil 	res = msg_vprintf (fmt, ap);
    143  1.1   phil 	va_end (ap);
    144  1.1   phil 	return res;
    145  1.1   phil }
    146  1.1   phil 
    147  1.1   phil 
    148  1.1   phil static void msg_vprompt (char *msg, char *def, char *val, int max_chars,
    149  1.1   phil 			 va_list ap)
    150  1.1   phil {
    151  1.1   phil 	int ch;
    152  1.1   phil 	int count = 0;
    153  1.1   phil 	int y,x;
    154  1.3    cgd 	char *ibuf = alloca(max_chars);
    155  1.1   phil 
    156  1.1   phil 	msg_vprintf (msg, ap);
    157  1.1   phil 	if (def != NULL && *def) {
    158  1.1   phil 		waddstr (msg_win, " [");
    159  1.1   phil 		waddstr (msg_win, def);
    160  1.1   phil 		waddstr (msg_win, "]");
    161  1.1   phil 	}
    162  1.1   phil 	waddstr (msg_win, ": ");
    163  1.1   phil 	wrefresh (msg_win);
    164  1.1   phil 
    165  1.1   phil 	while ((ch = wgetch(msg_win)) != '\n') {
    166  1.1   phil 		if (ch == 0x08 || ch == 0x7f) {  /* bs or del */
    167  1.1   phil 			if (count > 0) {
    168  1.1   phil 				count--;
    169  1.1   phil 				if (do_echo) {
    170  1.1   phil 					getyx(msg_win, y, x);
    171  1.1   phil 					x--;
    172  1.1   phil 					wmove(msg_win, y, x);
    173  1.1   phil 					wdelch(msg_win);
    174  1.1   phil 				}
    175  1.1   phil 			} else
    176  1.2  veego 				msg_beep ();
    177  1.4    cgd 		} else if (ch == 0x15) {	/* ^U; line kill */
    178  1.4    cgd 			while (count > 0) {
    179  1.4    cgd 				count--;
    180  1.4    cgd 				if (do_echo) {
    181  1.4    cgd 					getyx(msg_win, y, x);
    182  1.4    cgd 					x--;
    183  1.4    cgd 					wmove(msg_win, y, x);
    184  1.4    cgd 					wdelch(msg_win);
    185  1.4    cgd 				}
    186  1.4    cgd 			}
    187  1.4    cgd 		} else if (count < (max_chars - 1) && isprint(ch)) {
    188  1.1   phil 			if (do_echo)
    189  1.1   phil 				waddch (msg_win, ch);
    190  1.3    cgd 			ibuf[count++] = ch;
    191  1.1   phil 		} else
    192  1.2  veego 			msg_beep ();
    193  1.1   phil 		if (do_echo)
    194  1.1   phil 			wrefresh(msg_win);
    195  1.1   phil 	}
    196  1.1   phil 	if (do_echo)
    197  1.1   phil 		waddch(msg_win, '\n');
    198  1.1   phil 
    199  1.3    cgd 	/* copy the appropriate string to the output */
    200  1.3    cgd 	if (count != 0) {
    201  1.3    cgd 		ibuf[count] = '\0';
    202  1.3    cgd 		strcpy(val, ibuf);		/* size known to be OK */
    203  1.5    cgd 	} else if (def != NULL && val != def) {
    204  1.3    cgd 		strncpy(val, def, max_chars);
    205  1.3    cgd 		val[max_chars - 1] = '\0';
    206  1.3    cgd 	}
    207  1.1   phil }
    208  1.1   phil 
    209  1.1   phil void msg_prompt_addstr (char *fmt, char *def, char *val, int max_chars, ...)
    210  1.1   phil {
    211  1.1   phil 	va_list ap;
    212  1.1   phil 
    213  1.1   phil 	va_start (ap, max_chars);
    214  1.1   phil 	msg_vprompt (fmt, def, val, max_chars, ap);
    215  1.1   phil 	va_end(ap);
    216  1.1   phil }
    217  1.1   phil 
    218  1.1   phil void msg_prompt_add (int msg_no, char *def, char *val, int max_chars, ...)
    219  1.1   phil {
    220  1.1   phil 	va_list ap;
    221  1.1   phil 
    222  1.1   phil 	va_start (ap, max_chars);
    223  1.1   phil 	msg_vprompt (msg_list[msg_no], def, val, max_chars, ap);
    224  1.1   phil 	va_end(ap);
    225  1.1   phil }
    226  1.1   phil 
    227  1.1   phil void msg_prompt_str (char *msg, char *def, char *val, int max_chars, ...)
    228  1.1   phil {
    229  1.1   phil 	va_list ap;
    230  1.1   phil 
    231  1.7    cgd 	msg_clear();
    232  1.7    cgd 
    233  1.1   phil 	va_start (ap, max_chars);
    234  1.1   phil 	msg_vprompt (msg, def, val, max_chars, ap);
    235  1.1   phil 	va_end (ap);
    236  1.1   phil }
    237  1.1   phil 
    238  1.1   phil void msg_prompt (int msg_no, char *def, char *val, int max_chars, ...)
    239  1.1   phil {
    240  1.1   phil 	va_list ap;
    241  1.1   phil 
    242  1.7    cgd 	msg_clear();
    243  1.7    cgd 
    244  1.1   phil 	va_start (ap, max_chars);
    245  1.1   phil 	msg_vprompt (msg_list[msg_no], def, val, max_chars, ap);
    246  1.1   phil 	va_end (ap);
    247  1.1   phil }
    248  1.1   phil 
    249  1.1   phil void msg_noecho()
    250  1.1   phil {
    251  1.1   phil 	do_echo = 0;
    252  1.1   phil }
    253  1.1   phil 
    254  1.1   phil void msg_echo()
    255  1.1   phil {
    256  1.1   phil 	do_echo = 1;
    257  1.1   phil }
    258