summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuillaume Cottenceau <gc@mandriva.com>2001-02-16 16:50:22 +0000
committerGuillaume Cottenceau <gc@mandriva.com>2001-02-16 16:50:22 +0000
commit16eeff79f83b73f60ba483e0c76ad6eb29fd24eb (patch)
treebbbdd8543054c1af2918fe64a648da83599616cb
parent8cf293139495f2ee04a5fb89810767a72fb41a21 (diff)
downloaddrakx-backup-do-not-use-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar
drakx-backup-do-not-use-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.gz
drakx-backup-do-not-use-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.bz2
drakx-backup-do-not-use-16eeff79f83b73f60ba483e0c76ad6eb29fd24eb.tar.xz
drakx-backup-do-not-use-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.c36
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;
}