summaryrefslogtreecommitdiffstats
path: root/gnu/lib
diff options
context:
space:
mode:
authorjkh <jkh@FreeBSD.org>2001-02-24 18:52:56 +0000
committerjkh <jkh@FreeBSD.org>2001-02-24 18:52:56 +0000
commitaf5cfafd6a688cba2c71e8048a6bc55b65fb4729 (patch)
tree37095faadc7564cd99891b9e04644c879a8421d6 /gnu/lib
parent466f4e75a47668877c066f0afce7130dc0e5d9cc (diff)
downloadFreeBSD-src-af5cfafd6a688cba2c71e8048a6bc55b65fb4729.zip
FreeBSD-src-af5cfafd6a688cba2c71e8048a6bc55b65fb4729.tar.gz
Properly orient the buttons for yes/no and no/yes so that POLA is
observed. This fixes the "no/yes box jumps buttons around" problem. PR: gnu/24487 Submitted by: Gerhard Sittig <Gerhard.Sittig@gmx.net>
Diffstat (limited to 'gnu/lib')
-rw-r--r--gnu/lib/libdialog/yesno.c30
1 files changed, 11 insertions, 19 deletions
diff --git a/gnu/lib/libdialog/yesno.c b/gnu/lib/libdialog/yesno.c
index 3b7447f..9024470 100644
--- a/gnu/lib/libdialog/yesno.c
+++ b/gnu/lib/libdialog/yesno.c
@@ -50,7 +50,7 @@ dialog_noyes(unsigned char *title, unsigned char *prompt, int height, int width)
static int
dialog_yesno_proc(unsigned char *title, unsigned char *prompt, int height, int width, int yesdefault)
{
- int i, j, x, y, key = 0, button = 0;
+ int i, j, x, y, key, button;
WINDOW *dialog;
char *tmphlp;
@@ -114,11 +114,15 @@ dialog_yesno_proc(unsigned char *title, unsigned char *prompt, int height, int w
x = width/2-10;
y = height-2;
- print_button(dialog, yesdefault ? " No " : " Yes ", y, x+13, FALSE);
- print_button(dialog, yesdefault ? " Yes " : " No ", y, x, TRUE);
- wrefresh(dialog);
+ /* preset button 0 or 1 for YES or NO as the default */
+ key = 0;
+ button = !yesdefault;
while (key != ESC) {
+ print_button(dialog, " No ", y, x+13, button);
+ print_button(dialog, " Yes " , y, x, !button);
+ wrefresh(dialog);
+
key = wgetch(dialog);
switch (key) {
case 'Y':
@@ -137,27 +141,15 @@ dialog_yesno_proc(unsigned char *title, unsigned char *prompt, int height, int w
case KEY_DOWN:
case KEY_LEFT:
case KEY_RIGHT:
- if (!button) {
- button = 1; /* Indicates "No" button is selected */
- print_button(dialog, yesdefault ? " Yes " : " No ", y, x, FALSE);
- print_button(dialog, yesdefault ? " No " : " Yes ", y, x+13, TRUE);
- }
- else {
- button = 0; /* Indicates "Yes" button is selected */
- print_button(dialog, yesdefault ? " No " : " Yes ", y, x+13, FALSE);
- print_button(dialog, yesdefault ? " Yes " : " No ", y, x, TRUE);
- }
- wrefresh(dialog);
+ button = !button;
+ /* redrawn at the loop's entry */
break;
case ' ':
case '\r':
case '\n':
delwin(dialog);
restore_helpline(tmphlp);
- if (yesdefault)
- return button;
- else
- return !button;
+ return button;
case ESC:
break;
case KEY_F(1):
OpenPOWER on IntegriCloud