diff options
author | Guillaume Cottenceau <gc@mandriva.com> | 2001-02-16 16:50:22 +0000 |
---|---|---|
committer | Guillaume Cottenceau <gc@mandriva.com> | 2001-02-16 16:50:22 +0000 |
commit | 16eeff79f83b73f60ba483e0c76ad6eb29fd24eb (patch) | |
tree | bbbdd8543054c1af2918fe64a648da83599616cb | |
parent | 8cf293139495f2ee04a5fb89810767a72fb41a21 (diff) | |
download | drakx-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar drakx-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.gz drakx-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.bz2 drakx-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.xz drakx-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.zip |
display more nicely when there is a long list to choose from (1, 2 or 4 columns)
-rw-r--r-- | mdk-stage1/stdio-frontend.c | 36 |
1 files changed, 31 insertions, 5 deletions
diff --git a/mdk-stage1/stdio-frontend.c b/mdk-stage1/stdio-frontend.c index dfef79f6c..7e3cf9b83 100644 --- a/mdk-stage1/stdio-frontend.c +++ b/mdk-stage1/stdio-frontend.c @@ -46,7 +46,7 @@ void finish_frontend(void) static void get_any_response(void) { unsigned char t; - printf("> Press <enter> to proceed."); + printf(" (press <enter> to proceed)"); fflush(stdout); read(0, &t, 1); fcntl(0, F_SETFL, O_NONBLOCK); @@ -247,14 +247,40 @@ enum return_type ask_from_list(char *msg, char ** elems, char ** choice) char ** sav_elems = elems; int i, j; - printf("> %s\n(0) Cancel\n", msg); - i = 1; + i = 0; while (elems && *elems) { - printf("(%d) %s\n", i, *elems); i++; elems++; } + if (i < 10) { + printf("> %s\n(0) Cancel\n", msg); + for (j=0; j<i; j++) + printf("(%d) %s\n", j+1, sav_elems[j]); + } + else { + printf("> %s\n( 0) Cancel\n", msg); + if (i < 20) + for (j=0; j<i; j++) + printf("(%2d) %s\n", j+1, sav_elems[j]); + else { + if (i < 40) + for (j=0; j<i-1; j += 2) + printf("(%2d) %-34s (%2d) %s\n", j+1, sav_elems[j], j+2, sav_elems[j+1]); + else + for (j=0; j<i-3; j += 4) + printf("(%2d) %-14s (%2d) %-14s (%2d) %-14s (%2d) %s\n", + j+1, sav_elems[j], j+2, sav_elems[j+1], j+3, sav_elems[j+2], j+4, sav_elems[j+3]); + if (j < i) { + while (j < i) { + printf("(%2d) %-14s ", j+1, sav_elems[j]); + j++; + } + printf("\n"); + } + } + } + printf("? "); j = get_int_response(); @@ -262,7 +288,7 @@ enum return_type ask_from_list(char *msg, char ** elems, char ** choice) if (j == 0) return RETURN_BACK; - if (j >= 1 && j < i) { + if (j >= 1 && j <= i) { *choice = strdup(sav_elems[j-1]); return RETURN_OK; } |