xref: /utopia/UTPA2-700.0.x/projects/build/scripts/kconfig/lxdialog/menubox.c (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi /*
2*53ee8cc1Swenshuai.xi  *  menubox.c -- implements the menu box
3*53ee8cc1Swenshuai.xi  *
4*53ee8cc1Swenshuai.xi  *  ORIGINAL AUTHOR: Savio Lam (lam836@cs.cuhk.hk)
5*53ee8cc1Swenshuai.xi  *  MODIFIED FOR LINUX KERNEL CONFIG BY: William Roadcap (roadcapw@cfw.com)
6*53ee8cc1Swenshuai.xi  *
7*53ee8cc1Swenshuai.xi  *  This program is free software; you can redistribute it and/or
8*53ee8cc1Swenshuai.xi  *  modify it under the terms of the GNU General Public License
9*53ee8cc1Swenshuai.xi  *  as published by the Free Software Foundation; either version 2
10*53ee8cc1Swenshuai.xi  *  of the License, or (at your option) any later version.
11*53ee8cc1Swenshuai.xi  *
12*53ee8cc1Swenshuai.xi  *  This program is distributed in the hope that it will be useful,
13*53ee8cc1Swenshuai.xi  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
14*53ee8cc1Swenshuai.xi  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15*53ee8cc1Swenshuai.xi  *  GNU General Public License for more details.
16*53ee8cc1Swenshuai.xi  *
17*53ee8cc1Swenshuai.xi  *  You should have received a copy of the GNU General Public License
18*53ee8cc1Swenshuai.xi  *  along with this program; if not, write to the Free Software
19*53ee8cc1Swenshuai.xi  *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20*53ee8cc1Swenshuai.xi  */
21*53ee8cc1Swenshuai.xi 
22*53ee8cc1Swenshuai.xi /*
23*53ee8cc1Swenshuai.xi  *  Changes by Clifford Wolf (god@clifford.at)
24*53ee8cc1Swenshuai.xi  *
25*53ee8cc1Swenshuai.xi  *  [ 1998-06-13 ]
26*53ee8cc1Swenshuai.xi  *
27*53ee8cc1Swenshuai.xi  *    *)  A bugfix for the Page-Down problem
28*53ee8cc1Swenshuai.xi  *
29*53ee8cc1Swenshuai.xi  *    *)  Formerly when I used Page Down and Page Up, the cursor would be set
30*53ee8cc1Swenshuai.xi  *        to the first position in the menu box.  Now lxdialog is a bit
31*53ee8cc1Swenshuai.xi  *        smarter and works more like other menu systems (just have a look at
32*53ee8cc1Swenshuai.xi  *        it).
33*53ee8cc1Swenshuai.xi  *
34*53ee8cc1Swenshuai.xi  *    *)  Formerly if I selected something my scrolling would be broken because
35*53ee8cc1Swenshuai.xi  *        lxdialog is re-invoked by the Menuconfig shell script, can't
36*53ee8cc1Swenshuai.xi  *        remember the last scrolling position, and just sets it so that the
37*53ee8cc1Swenshuai.xi  *        cursor is at the bottom of the box.  Now it writes the temporary file
38*53ee8cc1Swenshuai.xi  *        lxdialog.scrltmp which contains this information. The file is
39*53ee8cc1Swenshuai.xi  *        deleted by lxdialog if the user leaves a submenu or enters a new
40*53ee8cc1Swenshuai.xi  *        one, but it would be nice if Menuconfig could make another "rm -f"
41*53ee8cc1Swenshuai.xi  *        just to be sure.  Just try it out - you will recognise a difference!
42*53ee8cc1Swenshuai.xi  *
43*53ee8cc1Swenshuai.xi  *  [ 1998-06-14 ]
44*53ee8cc1Swenshuai.xi  *
45*53ee8cc1Swenshuai.xi  *    *)  Now lxdialog is crash-safe against broken "lxdialog.scrltmp" files
46*53ee8cc1Swenshuai.xi  *        and menus change their size on the fly.
47*53ee8cc1Swenshuai.xi  *
48*53ee8cc1Swenshuai.xi  *    *)  If for some reason the last scrolling position is not saved by
49*53ee8cc1Swenshuai.xi  *        lxdialog, it sets the scrolling so that the selected item is in the
50*53ee8cc1Swenshuai.xi  *        middle of the menu box, not at the bottom.
51*53ee8cc1Swenshuai.xi  *
52*53ee8cc1Swenshuai.xi  * 02 January 1999, Michael Elizabeth Chastain (mec@shout.net)
53*53ee8cc1Swenshuai.xi  * Reset 'scroll' to 0 if the value from lxdialog.scrltmp is bogus.
54*53ee8cc1Swenshuai.xi  * This fixes a bug in Menuconfig where using ' ' to descend into menus
55*53ee8cc1Swenshuai.xi  * would leave mis-synchronized lxdialog.scrltmp files lying around,
56*53ee8cc1Swenshuai.xi  * fscanf would read in 'scroll', and eventually that value would get used.
57*53ee8cc1Swenshuai.xi  */
58*53ee8cc1Swenshuai.xi 
59*53ee8cc1Swenshuai.xi #include "dialog.h"
60*53ee8cc1Swenshuai.xi 
61*53ee8cc1Swenshuai.xi static int menu_width, item_x;
62*53ee8cc1Swenshuai.xi 
63*53ee8cc1Swenshuai.xi /*
64*53ee8cc1Swenshuai.xi  * Print menu item
65*53ee8cc1Swenshuai.xi  */
do_print_item(WINDOW * win,const char * item,int line_y,int selected,int hotkey)66*53ee8cc1Swenshuai.xi static void do_print_item(WINDOW * win, const char *item, int line_y,
67*53ee8cc1Swenshuai.xi                           int selected, int hotkey)
68*53ee8cc1Swenshuai.xi {
69*53ee8cc1Swenshuai.xi 	int j;
70*53ee8cc1Swenshuai.xi 	char *menu_item = malloc(menu_width + 1);
71*53ee8cc1Swenshuai.xi 
72*53ee8cc1Swenshuai.xi 	strncpy(menu_item, item, menu_width - item_x);
73*53ee8cc1Swenshuai.xi 	menu_item[menu_width - item_x] = '\0';
74*53ee8cc1Swenshuai.xi 	j = first_alpha(menu_item, "YyNnMmHh");
75*53ee8cc1Swenshuai.xi 
76*53ee8cc1Swenshuai.xi 	/* Clear 'residue' of last item */
77*53ee8cc1Swenshuai.xi 	wattrset(win, dlg.menubox.atr);
78*53ee8cc1Swenshuai.xi 	wmove(win, line_y, 0);
79*53ee8cc1Swenshuai.xi #if OLD_NCURSES
80*53ee8cc1Swenshuai.xi 	{
81*53ee8cc1Swenshuai.xi 		int i;
82*53ee8cc1Swenshuai.xi 		for (i = 0; i < menu_width; i++)
83*53ee8cc1Swenshuai.xi 			waddch(win, ' ');
84*53ee8cc1Swenshuai.xi 	}
85*53ee8cc1Swenshuai.xi #else
86*53ee8cc1Swenshuai.xi 	wclrtoeol(win);
87*53ee8cc1Swenshuai.xi #endif
88*53ee8cc1Swenshuai.xi 	wattrset(win, selected ? dlg.item_selected.atr : dlg.item.atr);
89*53ee8cc1Swenshuai.xi 	mvwaddstr(win, line_y, item_x, menu_item);
90*53ee8cc1Swenshuai.xi 	if (hotkey) {
91*53ee8cc1Swenshuai.xi 		wattrset(win, selected ? dlg.tag_key_selected.atr
92*53ee8cc1Swenshuai.xi 			 : dlg.tag_key.atr);
93*53ee8cc1Swenshuai.xi 		mvwaddch(win, line_y, item_x + j, menu_item[j]);
94*53ee8cc1Swenshuai.xi 	}
95*53ee8cc1Swenshuai.xi 	if (selected) {
96*53ee8cc1Swenshuai.xi 		wmove(win, line_y, item_x + 1);
97*53ee8cc1Swenshuai.xi 	}
98*53ee8cc1Swenshuai.xi 	free(menu_item);
99*53ee8cc1Swenshuai.xi 	wrefresh(win);
100*53ee8cc1Swenshuai.xi }
101*53ee8cc1Swenshuai.xi 
102*53ee8cc1Swenshuai.xi #define print_item(index, choice, selected)				\
103*53ee8cc1Swenshuai.xi do {									\
104*53ee8cc1Swenshuai.xi 	item_set(index);						\
105*53ee8cc1Swenshuai.xi 	do_print_item(menu, item_str(), choice, selected, !item_is_tag(':')); \
106*53ee8cc1Swenshuai.xi } while (0)
107*53ee8cc1Swenshuai.xi 
108*53ee8cc1Swenshuai.xi /*
109*53ee8cc1Swenshuai.xi  * Print the scroll indicators.
110*53ee8cc1Swenshuai.xi  */
print_arrows(WINDOW * win,int item_no,int scroll,int y,int x,int height)111*53ee8cc1Swenshuai.xi static void print_arrows(WINDOW * win, int item_no, int scroll, int y, int x,
112*53ee8cc1Swenshuai.xi 			 int height)
113*53ee8cc1Swenshuai.xi {
114*53ee8cc1Swenshuai.xi 	int cur_y, cur_x;
115*53ee8cc1Swenshuai.xi 
116*53ee8cc1Swenshuai.xi 	getyx(win, cur_y, cur_x);
117*53ee8cc1Swenshuai.xi 
118*53ee8cc1Swenshuai.xi 	wmove(win, y, x);
119*53ee8cc1Swenshuai.xi 
120*53ee8cc1Swenshuai.xi 	if (scroll > 0) {
121*53ee8cc1Swenshuai.xi 		wattrset(win, dlg.uarrow.atr);
122*53ee8cc1Swenshuai.xi 		waddch(win, ACS_UARROW);
123*53ee8cc1Swenshuai.xi 		waddstr(win, "(-)");
124*53ee8cc1Swenshuai.xi 	} else {
125*53ee8cc1Swenshuai.xi 		wattrset(win, dlg.menubox.atr);
126*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
127*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
128*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
129*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
130*53ee8cc1Swenshuai.xi 	}
131*53ee8cc1Swenshuai.xi 
132*53ee8cc1Swenshuai.xi 	y = y + height + 1;
133*53ee8cc1Swenshuai.xi 	wmove(win, y, x);
134*53ee8cc1Swenshuai.xi 	wrefresh(win);
135*53ee8cc1Swenshuai.xi 
136*53ee8cc1Swenshuai.xi 	if ((height < item_no) && (scroll + height < item_no)) {
137*53ee8cc1Swenshuai.xi 		wattrset(win, dlg.darrow.atr);
138*53ee8cc1Swenshuai.xi 		waddch(win, ACS_DARROW);
139*53ee8cc1Swenshuai.xi 		waddstr(win, "(+)");
140*53ee8cc1Swenshuai.xi 	} else {
141*53ee8cc1Swenshuai.xi 		wattrset(win, dlg.menubox_border.atr);
142*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
143*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
144*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
145*53ee8cc1Swenshuai.xi 		waddch(win, ACS_HLINE);
146*53ee8cc1Swenshuai.xi 	}
147*53ee8cc1Swenshuai.xi 
148*53ee8cc1Swenshuai.xi 	wmove(win, cur_y, cur_x);
149*53ee8cc1Swenshuai.xi 	wrefresh(win);
150*53ee8cc1Swenshuai.xi }
151*53ee8cc1Swenshuai.xi 
152*53ee8cc1Swenshuai.xi /*
153*53ee8cc1Swenshuai.xi  * Display the termination buttons.
154*53ee8cc1Swenshuai.xi  */
print_buttons(WINDOW * win,int height,int width,int selected)155*53ee8cc1Swenshuai.xi static void print_buttons(WINDOW * win, int height, int width, int selected)
156*53ee8cc1Swenshuai.xi {
157*53ee8cc1Swenshuai.xi 	int x = width / 2 - 16;
158*53ee8cc1Swenshuai.xi 	int y = height - 2;
159*53ee8cc1Swenshuai.xi 
160*53ee8cc1Swenshuai.xi 	print_button(win, gettext("Select"), y, x, selected == 0);
161*53ee8cc1Swenshuai.xi 	print_button(win, gettext(" Exit "), y, x + 12, selected == 1);
162*53ee8cc1Swenshuai.xi 	print_button(win, gettext(" Help "), y, x + 24, selected == 2);
163*53ee8cc1Swenshuai.xi 
164*53ee8cc1Swenshuai.xi 	wmove(win, y, x + 1 + 12 * selected);
165*53ee8cc1Swenshuai.xi 	wrefresh(win);
166*53ee8cc1Swenshuai.xi }
167*53ee8cc1Swenshuai.xi 
168*53ee8cc1Swenshuai.xi /* scroll up n lines (n may be negative) */
do_scroll(WINDOW * win,int * scroll,int n)169*53ee8cc1Swenshuai.xi static void do_scroll(WINDOW *win, int *scroll, int n)
170*53ee8cc1Swenshuai.xi {
171*53ee8cc1Swenshuai.xi 	/* Scroll menu up */
172*53ee8cc1Swenshuai.xi 	scrollok(win, TRUE);
173*53ee8cc1Swenshuai.xi 	wscrl(win, n);
174*53ee8cc1Swenshuai.xi 	scrollok(win, FALSE);
175*53ee8cc1Swenshuai.xi 	*scroll = *scroll + n;
176*53ee8cc1Swenshuai.xi 	wrefresh(win);
177*53ee8cc1Swenshuai.xi }
178*53ee8cc1Swenshuai.xi 
179*53ee8cc1Swenshuai.xi /*
180*53ee8cc1Swenshuai.xi  * Display a menu for choosing among a number of options
181*53ee8cc1Swenshuai.xi  */
dialog_menu(const char * title,const char * prompt,const void * selected,int * s_scroll)182*53ee8cc1Swenshuai.xi int dialog_menu(const char *title, const char *prompt,
183*53ee8cc1Swenshuai.xi                 const void *selected, int *s_scroll)
184*53ee8cc1Swenshuai.xi {
185*53ee8cc1Swenshuai.xi 	int i, j, x, y, box_x, box_y;
186*53ee8cc1Swenshuai.xi 	int height, width, menu_height;
187*53ee8cc1Swenshuai.xi 	int key = 0, button = 0, scroll = 0, choice = 0;
188*53ee8cc1Swenshuai.xi 	int first_item =  0, max_choice;
189*53ee8cc1Swenshuai.xi 	WINDOW *dialog, *menu;
190*53ee8cc1Swenshuai.xi 
191*53ee8cc1Swenshuai.xi do_resize:
192*53ee8cc1Swenshuai.xi 	height = getmaxy(stdscr);
193*53ee8cc1Swenshuai.xi 	width = getmaxx(stdscr);
194*53ee8cc1Swenshuai.xi 	if (height < 15 || width < 65)
195*53ee8cc1Swenshuai.xi 		return -ERRDISPLAYTOOSMALL;
196*53ee8cc1Swenshuai.xi 
197*53ee8cc1Swenshuai.xi 	height -= 4;
198*53ee8cc1Swenshuai.xi 	width  -= 5;
199*53ee8cc1Swenshuai.xi 	menu_height = height - 10;
200*53ee8cc1Swenshuai.xi 
201*53ee8cc1Swenshuai.xi 	max_choice = MIN(menu_height, item_count());
202*53ee8cc1Swenshuai.xi 
203*53ee8cc1Swenshuai.xi 	/* center dialog box on screen */
204*53ee8cc1Swenshuai.xi 	x = (COLS - width) / 2;
205*53ee8cc1Swenshuai.xi 	y = (LINES - height) / 2;
206*53ee8cc1Swenshuai.xi 
207*53ee8cc1Swenshuai.xi 	draw_shadow(stdscr, y, x, height, width);
208*53ee8cc1Swenshuai.xi 
209*53ee8cc1Swenshuai.xi 	dialog = newwin(height, width, y, x);
210*53ee8cc1Swenshuai.xi 	keypad(dialog, TRUE);
211*53ee8cc1Swenshuai.xi 
212*53ee8cc1Swenshuai.xi 	draw_box(dialog, 0, 0, height, width,
213*53ee8cc1Swenshuai.xi 		 dlg.dialog.atr, dlg.border.atr);
214*53ee8cc1Swenshuai.xi 	wattrset(dialog, dlg.border.atr);
215*53ee8cc1Swenshuai.xi 	mvwaddch(dialog, height - 3, 0, ACS_LTEE);
216*53ee8cc1Swenshuai.xi 	for (i = 0; i < width - 2; i++)
217*53ee8cc1Swenshuai.xi 		waddch(dialog, ACS_HLINE);
218*53ee8cc1Swenshuai.xi 	wattrset(dialog, dlg.dialog.atr);
219*53ee8cc1Swenshuai.xi 	wbkgdset(dialog, dlg.dialog.atr & A_COLOR);
220*53ee8cc1Swenshuai.xi 	waddch(dialog, ACS_RTEE);
221*53ee8cc1Swenshuai.xi 
222*53ee8cc1Swenshuai.xi 	print_title(dialog, title, width);
223*53ee8cc1Swenshuai.xi 
224*53ee8cc1Swenshuai.xi 	wattrset(dialog, dlg.dialog.atr);
225*53ee8cc1Swenshuai.xi 	print_autowrap(dialog, prompt, width - 2, 1, 3);
226*53ee8cc1Swenshuai.xi 
227*53ee8cc1Swenshuai.xi 	menu_width = width - 6;
228*53ee8cc1Swenshuai.xi 	box_y = height - menu_height - 5;
229*53ee8cc1Swenshuai.xi 	box_x = (width - menu_width) / 2 - 1;
230*53ee8cc1Swenshuai.xi 
231*53ee8cc1Swenshuai.xi 	/* create new window for the menu */
232*53ee8cc1Swenshuai.xi 	menu = subwin(dialog, menu_height, menu_width,
233*53ee8cc1Swenshuai.xi 		      y + box_y + 1, x + box_x + 1);
234*53ee8cc1Swenshuai.xi 	keypad(menu, TRUE);
235*53ee8cc1Swenshuai.xi 
236*53ee8cc1Swenshuai.xi 	/* draw a box around the menu items */
237*53ee8cc1Swenshuai.xi 	draw_box(dialog, box_y, box_x, menu_height + 2, menu_width + 2,
238*53ee8cc1Swenshuai.xi 		 dlg.menubox_border.atr, dlg.menubox.atr);
239*53ee8cc1Swenshuai.xi 
240*53ee8cc1Swenshuai.xi 	if (menu_width >= 80)
241*53ee8cc1Swenshuai.xi 		item_x = (menu_width - 70) / 2;
242*53ee8cc1Swenshuai.xi 	else
243*53ee8cc1Swenshuai.xi 		item_x = 4;
244*53ee8cc1Swenshuai.xi 
245*53ee8cc1Swenshuai.xi 	/* Set choice to default item */
246*53ee8cc1Swenshuai.xi 	item_foreach()
247*53ee8cc1Swenshuai.xi 		if (selected && (selected == item_data()))
248*53ee8cc1Swenshuai.xi 			choice = item_n();
249*53ee8cc1Swenshuai.xi 	/* get the saved scroll info */
250*53ee8cc1Swenshuai.xi 	scroll = *s_scroll;
251*53ee8cc1Swenshuai.xi 	if ((scroll <= choice) && (scroll + max_choice > choice) &&
252*53ee8cc1Swenshuai.xi 	   (scroll >= 0) && (scroll + max_choice <= item_count())) {
253*53ee8cc1Swenshuai.xi 		first_item = scroll;
254*53ee8cc1Swenshuai.xi 		choice = choice - scroll;
255*53ee8cc1Swenshuai.xi 	} else {
256*53ee8cc1Swenshuai.xi 		scroll = 0;
257*53ee8cc1Swenshuai.xi 	}
258*53ee8cc1Swenshuai.xi 	if ((choice >= max_choice)) {
259*53ee8cc1Swenshuai.xi 		if (choice >= item_count() - max_choice / 2)
260*53ee8cc1Swenshuai.xi 			scroll = first_item = item_count() - max_choice;
261*53ee8cc1Swenshuai.xi 		else
262*53ee8cc1Swenshuai.xi 			scroll = first_item = choice - max_choice / 2;
263*53ee8cc1Swenshuai.xi 		choice = choice - scroll;
264*53ee8cc1Swenshuai.xi 	}
265*53ee8cc1Swenshuai.xi 
266*53ee8cc1Swenshuai.xi 	/* Print the menu */
267*53ee8cc1Swenshuai.xi 	for (i = 0; i < max_choice; i++) {
268*53ee8cc1Swenshuai.xi 		print_item(first_item + i, i, i == choice);
269*53ee8cc1Swenshuai.xi 	}
270*53ee8cc1Swenshuai.xi 
271*53ee8cc1Swenshuai.xi 	wnoutrefresh(menu);
272*53ee8cc1Swenshuai.xi 
273*53ee8cc1Swenshuai.xi 	print_arrows(dialog, item_count(), scroll,
274*53ee8cc1Swenshuai.xi 		     box_y, box_x + item_x + 1, menu_height);
275*53ee8cc1Swenshuai.xi 
276*53ee8cc1Swenshuai.xi 	print_buttons(dialog, height, width, 0);
277*53ee8cc1Swenshuai.xi 	wmove(menu, choice, item_x + 1);
278*53ee8cc1Swenshuai.xi 	wrefresh(menu);
279*53ee8cc1Swenshuai.xi 
280*53ee8cc1Swenshuai.xi 	while (key != KEY_ESC) {
281*53ee8cc1Swenshuai.xi 		key = wgetch(menu);
282*53ee8cc1Swenshuai.xi 
283*53ee8cc1Swenshuai.xi 		if (key < 256 && isalpha(key))
284*53ee8cc1Swenshuai.xi 			key = tolower(key);
285*53ee8cc1Swenshuai.xi 
286*53ee8cc1Swenshuai.xi 		if (strchr("ynmh", key))
287*53ee8cc1Swenshuai.xi 			i = max_choice;
288*53ee8cc1Swenshuai.xi 		else {
289*53ee8cc1Swenshuai.xi 			for (i = choice + 1; i < max_choice; i++) {
290*53ee8cc1Swenshuai.xi 				item_set(scroll + i);
291*53ee8cc1Swenshuai.xi 				j = first_alpha(item_str(), "YyNnMmHh");
292*53ee8cc1Swenshuai.xi 				if (key == tolower(item_str()[j]))
293*53ee8cc1Swenshuai.xi 					break;
294*53ee8cc1Swenshuai.xi 			}
295*53ee8cc1Swenshuai.xi 			if (i == max_choice)
296*53ee8cc1Swenshuai.xi 				for (i = 0; i < max_choice; i++) {
297*53ee8cc1Swenshuai.xi 					item_set(scroll + i);
298*53ee8cc1Swenshuai.xi 					j = first_alpha(item_str(), "YyNnMmHh");
299*53ee8cc1Swenshuai.xi 					if (key == tolower(item_str()[j]))
300*53ee8cc1Swenshuai.xi 						break;
301*53ee8cc1Swenshuai.xi 				}
302*53ee8cc1Swenshuai.xi 		}
303*53ee8cc1Swenshuai.xi 
304*53ee8cc1Swenshuai.xi 		if (i < max_choice ||
305*53ee8cc1Swenshuai.xi 		    key == KEY_UP || key == KEY_DOWN ||
306*53ee8cc1Swenshuai.xi 		    key == '-' || key == '+' ||
307*53ee8cc1Swenshuai.xi 		    key == KEY_PPAGE || key == KEY_NPAGE) {
308*53ee8cc1Swenshuai.xi 			/* Remove highligt of current item */
309*53ee8cc1Swenshuai.xi 			print_item(scroll + choice, choice, FALSE);
310*53ee8cc1Swenshuai.xi 
311*53ee8cc1Swenshuai.xi 			if (key == KEY_UP || key == '-') {
312*53ee8cc1Swenshuai.xi 				if (choice < 2 && scroll) {
313*53ee8cc1Swenshuai.xi 					/* Scroll menu down */
314*53ee8cc1Swenshuai.xi 					do_scroll(menu, &scroll, -1);
315*53ee8cc1Swenshuai.xi 
316*53ee8cc1Swenshuai.xi 					print_item(scroll, 0, FALSE);
317*53ee8cc1Swenshuai.xi 				} else
318*53ee8cc1Swenshuai.xi 					choice = MAX(choice - 1, 0);
319*53ee8cc1Swenshuai.xi 
320*53ee8cc1Swenshuai.xi 			} else if (key == KEY_DOWN || key == '+') {
321*53ee8cc1Swenshuai.xi 				print_item(scroll+choice, choice, FALSE);
322*53ee8cc1Swenshuai.xi 
323*53ee8cc1Swenshuai.xi 				if ((choice > max_choice - 3) &&
324*53ee8cc1Swenshuai.xi 				    (scroll + max_choice < item_count())) {
325*53ee8cc1Swenshuai.xi 					/* Scroll menu up */
326*53ee8cc1Swenshuai.xi 					do_scroll(menu, &scroll, 1);
327*53ee8cc1Swenshuai.xi 
328*53ee8cc1Swenshuai.xi 					print_item(scroll+max_choice - 1,
329*53ee8cc1Swenshuai.xi 						   max_choice - 1, FALSE);
330*53ee8cc1Swenshuai.xi 				} else
331*53ee8cc1Swenshuai.xi 					choice = MIN(choice + 1, max_choice - 1);
332*53ee8cc1Swenshuai.xi 
333*53ee8cc1Swenshuai.xi 			} else if (key == KEY_PPAGE) {
334*53ee8cc1Swenshuai.xi 				scrollok(menu, TRUE);
335*53ee8cc1Swenshuai.xi 				for (i = 0; (i < max_choice); i++) {
336*53ee8cc1Swenshuai.xi 					if (scroll > 0) {
337*53ee8cc1Swenshuai.xi 						do_scroll(menu, &scroll, -1);
338*53ee8cc1Swenshuai.xi 						print_item(scroll, 0, FALSE);
339*53ee8cc1Swenshuai.xi 					} else {
340*53ee8cc1Swenshuai.xi 						if (choice > 0)
341*53ee8cc1Swenshuai.xi 							choice--;
342*53ee8cc1Swenshuai.xi 					}
343*53ee8cc1Swenshuai.xi 				}
344*53ee8cc1Swenshuai.xi 
345*53ee8cc1Swenshuai.xi 			} else if (key == KEY_NPAGE) {
346*53ee8cc1Swenshuai.xi 				for (i = 0; (i < max_choice); i++) {
347*53ee8cc1Swenshuai.xi 					if (scroll + max_choice < item_count()) {
348*53ee8cc1Swenshuai.xi 						do_scroll(menu, &scroll, 1);
349*53ee8cc1Swenshuai.xi 						print_item(scroll+max_choice-1,
350*53ee8cc1Swenshuai.xi 							   max_choice - 1, FALSE);
351*53ee8cc1Swenshuai.xi 					} else {
352*53ee8cc1Swenshuai.xi 						if (choice + 1 < max_choice)
353*53ee8cc1Swenshuai.xi 							choice++;
354*53ee8cc1Swenshuai.xi 					}
355*53ee8cc1Swenshuai.xi 				}
356*53ee8cc1Swenshuai.xi 			} else
357*53ee8cc1Swenshuai.xi 				choice = i;
358*53ee8cc1Swenshuai.xi 
359*53ee8cc1Swenshuai.xi 			print_item(scroll + choice, choice, TRUE);
360*53ee8cc1Swenshuai.xi 
361*53ee8cc1Swenshuai.xi 			print_arrows(dialog, item_count(), scroll,
362*53ee8cc1Swenshuai.xi 				     box_y, box_x + item_x + 1, menu_height);
363*53ee8cc1Swenshuai.xi 
364*53ee8cc1Swenshuai.xi 			wnoutrefresh(dialog);
365*53ee8cc1Swenshuai.xi 			wrefresh(menu);
366*53ee8cc1Swenshuai.xi 
367*53ee8cc1Swenshuai.xi 			continue;	/* wait for another key press */
368*53ee8cc1Swenshuai.xi 		}
369*53ee8cc1Swenshuai.xi 
370*53ee8cc1Swenshuai.xi 		switch (key) {
371*53ee8cc1Swenshuai.xi 		case KEY_LEFT:
372*53ee8cc1Swenshuai.xi 		case TAB:
373*53ee8cc1Swenshuai.xi 		case KEY_RIGHT:
374*53ee8cc1Swenshuai.xi 			button = ((key == KEY_LEFT ? --button : ++button) < 0)
375*53ee8cc1Swenshuai.xi 			    ? 2 : (button > 2 ? 0 : button);
376*53ee8cc1Swenshuai.xi 
377*53ee8cc1Swenshuai.xi 			print_buttons(dialog, height, width, button);
378*53ee8cc1Swenshuai.xi 			wrefresh(menu);
379*53ee8cc1Swenshuai.xi 			break;
380*53ee8cc1Swenshuai.xi 		case ' ':
381*53ee8cc1Swenshuai.xi 		case 's':
382*53ee8cc1Swenshuai.xi 		case 'y':
383*53ee8cc1Swenshuai.xi 		case 'n':
384*53ee8cc1Swenshuai.xi 		case 'm':
385*53ee8cc1Swenshuai.xi 		case '/':
386*53ee8cc1Swenshuai.xi 		case 'h':
387*53ee8cc1Swenshuai.xi 		case '?':
388*53ee8cc1Swenshuai.xi 		case 'z':
389*53ee8cc1Swenshuai.xi 		case '\n':
390*53ee8cc1Swenshuai.xi 			/* save scroll info */
391*53ee8cc1Swenshuai.xi 			*s_scroll = scroll;
392*53ee8cc1Swenshuai.xi 			delwin(menu);
393*53ee8cc1Swenshuai.xi 			delwin(dialog);
394*53ee8cc1Swenshuai.xi 			item_set(scroll + choice);
395*53ee8cc1Swenshuai.xi 			item_set_selected(1);
396*53ee8cc1Swenshuai.xi 			switch (key) {
397*53ee8cc1Swenshuai.xi 			case 'h':
398*53ee8cc1Swenshuai.xi 			case '?':
399*53ee8cc1Swenshuai.xi 				return 2;
400*53ee8cc1Swenshuai.xi 			case 's':
401*53ee8cc1Swenshuai.xi 			case 'y':
402*53ee8cc1Swenshuai.xi 				return 3;
403*53ee8cc1Swenshuai.xi 			case 'n':
404*53ee8cc1Swenshuai.xi 				return 4;
405*53ee8cc1Swenshuai.xi 			case 'm':
406*53ee8cc1Swenshuai.xi 				return 5;
407*53ee8cc1Swenshuai.xi 			case ' ':
408*53ee8cc1Swenshuai.xi 				return 6;
409*53ee8cc1Swenshuai.xi 			case '/':
410*53ee8cc1Swenshuai.xi 				return 7;
411*53ee8cc1Swenshuai.xi 			case 'z':
412*53ee8cc1Swenshuai.xi 				return 8;
413*53ee8cc1Swenshuai.xi 			case '\n':
414*53ee8cc1Swenshuai.xi 				return button;
415*53ee8cc1Swenshuai.xi 			}
416*53ee8cc1Swenshuai.xi 			return 0;
417*53ee8cc1Swenshuai.xi 		case 'e':
418*53ee8cc1Swenshuai.xi 		case 'x':
419*53ee8cc1Swenshuai.xi 			key = KEY_ESC;
420*53ee8cc1Swenshuai.xi 			break;
421*53ee8cc1Swenshuai.xi 		case KEY_ESC:
422*53ee8cc1Swenshuai.xi 			key = on_key_esc(menu);
423*53ee8cc1Swenshuai.xi 			break;
424*53ee8cc1Swenshuai.xi 		case KEY_RESIZE:
425*53ee8cc1Swenshuai.xi 			on_key_resize();
426*53ee8cc1Swenshuai.xi 			delwin(menu);
427*53ee8cc1Swenshuai.xi 			delwin(dialog);
428*53ee8cc1Swenshuai.xi 			goto do_resize;
429*53ee8cc1Swenshuai.xi 		}
430*53ee8cc1Swenshuai.xi 	}
431*53ee8cc1Swenshuai.xi 	delwin(menu);
432*53ee8cc1Swenshuai.xi 	delwin(dialog);
433*53ee8cc1Swenshuai.xi 	return key;		/* ESC pressed */
434*53ee8cc1Swenshuai.xi }
435