yn_function (trunk only)

Explicitly truncate the query prompt string to QBUFSZ-1 characters.
For tty and Amiga, no longer include the choices and default within that
length limit; use a bigger buffer to hold them along with the prompt.
[See cvs log for doc/window.doc for more details.]
This commit is contained in:
nethack.rankin
2006-10-22 05:59:26 +00:00
parent 3dc9791685
commit 054a74d378
7 changed files with 48 additions and 24 deletions

View File

@@ -1094,7 +1094,7 @@ char def;
register char q;
char rtmp[40];
boolean digit_ok, allow_num;
char prompt[QBUFSZ];
char prompt[BUFSZ];
register struct amii_WinDesc *cw;
if( cw = amii_wins[ WIN_MESSAGE ] )
@@ -1102,13 +1102,16 @@ char def;
if (resp) {
char *rb, respbuf[QBUFSZ];
allow_num = (index(resp, '#') != 0);
allow_num = (index(resp, '#') != 0);
Strcpy(respbuf, resp);
/* any acceptable responses that follow <esc> aren't displayed */
if ((rb = index(respbuf, '\033')) != 0) *rb = '\0';
Sprintf(prompt, "%s [%s] ", query, respbuf);
if (def) Sprintf(eos(prompt), "(%c) ", def);
pline("%s", prompt);
(void)strncpy(prompt, query, QBUFSZ-1);
prompt[QBUFSZ-1] = '\0';
Sprintf(eos(prompt), " [%s]", respbuf);
if (def) Sprintf(eos(prompt), " (%c)", def);
Strcat(prompt, " ");
pline("%s", prompt);
} else {
amii_putstr(WIN_MESSAGE, 0, query);
cursor_on(WIN_MESSAGE);

View File

@@ -1392,8 +1392,11 @@ char mswin_yn_function(const char *question, const char *choices,
/* anything beyond <esc> is hidden */
*cb = '\0';
}
sprintf(message, "%s [%s] ", question, choicebuf);
if (def) sprintf(eos(message), "(%c) ", def);
(void)strncpy(message, question, QBUFSZ-1);
message[QBUFSZ-1] = '\0';
sprintf(eos(message), " [%s]", choicebuf);
if (def) sprintf(eos(message), " (%c)", def);
Strcat(message, " ");
/* escape maps to 'q' or 'n' or default, in that order */
yn_esc_map = (index(choices, 'q') ? 'q' :
(index(choices, 'n') ? 'n' : def));

View File

@@ -4963,8 +4963,11 @@ char NetHackQtBind::qt_yn_function(const char *question, const char *choices, CH
// anything beyond <esc> is hidden
*cb = '\0';
}
Sprintf(message, "%s [%s] ", question, choicebuf);
if (def) Sprintf(eos(message), "(%c) ", def);
(void)strncpy(message, question, QBUFSZ-1);
message[QBUFSZ-1] = '\0';
Sprintf(eos(message), " [%s]", choicebuf);
if (def) Sprintf(eos(message), " (%c)", def);
Strcat(message, " ");
// escape maps to 'q' or 'n' or default, in that order
yn_esc_map = (index(choices, 'q') ? 'q' :
(index(choices, 'n') ? 'n' : def));

View File

@@ -1669,7 +1669,7 @@ X11_yn_function(ques, choices, def)
char def;
{
static Boolean need_to_init = True;
char buf[QBUFSZ];
char buf[BUFSZ];
Arg args[4];
Cardinal num_args;
@@ -1692,19 +1692,23 @@ X11_yn_function(ques, choices, def)
Strcpy(choicebuf, choices); /* anything beyond <esc> is hidden */
if ((cb = index(choicebuf, '\033')) != 0) *cb = '\0';
/* ques [choices] (def) */
if ((int)(1 + strlen(ques) + 2 + strlen(choicebuf) + 4) >= QBUFSZ)
panic("yn_function: question too long");
Sprintf(buf, "%s [%s] ", ques, choicebuf);
if (def) Sprintf(eos(buf), "(%c) ", def);
if ((int)(1 + strlen(ques) + 2 + strlen(choicebuf) + 4) >= BUFSZ)
panic("X11_yn_function: question too long");
(void)strncpy(buf, ques, QBUFSZ-1);
buf[QBUFSZ-1] = '\0';
Sprintf(eos(buf), " [%s]", choicebuf);
if (def) Sprintf(eos(buf), " (%c)", def);
Strcat(buf, " ");
/* escape maps to 'q' or 'n' or default, in that order */
yn_esc_map = (index(choices, 'q') ? 'q' :
(index(choices, 'n') ? 'n' :
def));
} else {
if ((int)(1 + strlen(ques)) >= QBUFSZ)
panic("yn_function: question too long");
if ((int)(1 + strlen(ques) + 1) >= BUFSZ)
panic("X11_yn_function: question too long");
Strcpy(buf, ques);
Strcat(buf, " ");
}
if (!appResources.slow && need_to_init) {

View File

@@ -1050,8 +1050,11 @@ char gnome_yn_function(const char *question, const char *choices,
/* anything beyond <esc> is hidden */
*cb = '\0';
}
sprintf(message, "%s [%s] ", question, choicebuf);
if (def) sprintf(eos(message), "(%c) ", def);
(void)strncpy(message, question, QBUFSZ-1);
message[QBUFSZ-1] = '\0';
sprintf(eos(message), " [%s]", choicebuf);
if (def) sprintf(eos(message), " (%c)", def);
Strcat(message, " ");
/* escape maps to 'q' or 'n' or default, in that order */
yn_esc_map = (index(choices, 'q') ? 'q' :
(index(choices, 'n') ? 'n' : def));

View File

@@ -425,9 +425,9 @@ char def;
boolean digit_ok, allow_num;
struct WinDesc *cw = wins[WIN_MESSAGE];
boolean doprev = 0;
char prompt[QBUFSZ];
char prompt[BUFSZ];
#ifdef UNICODE_WIDEWINPORT
nhwchar wprompt[QBUFSZ];
nhwchar wprompt[BUFSZ];
#endif
if(ttyDisplay->toplin == 1 && !(cw->flags & WIN_STOP)) more();
@@ -441,8 +441,13 @@ char def;
Strcpy(respbuf, resp);
/* any acceptable responses that follow <esc> aren't displayed */
if ((rb = index(respbuf, '\033')) != 0) *rb = '\0';
Sprintf(prompt, "%s [%s] ", query, respbuf);
if (def) Sprintf(eos(prompt), "(%c) ", def);
(void)strncpy(prompt, query, QBUFSZ-1);
prompt[QBUFSZ-1] = '\0';
Sprintf(eos(prompt), " [%s]", respbuf);
if (def) Sprintf(eos(prompt), " (%c)", def);
/* not pline("%s ", prompt);
trailing space is wanted here in case of reprompt */
Strcat(prompt, " ");
pline("%s", prompt);
} else {
pline("%s ", query);

View File

@@ -1447,8 +1447,11 @@ char mswin_yn_function(const char *question, const char *choices,
/* anything beyond <esc> is hidden */
*cb = '\0';
}
sprintf(message, "%s [%s] ", question, choicebuf);
if (def) sprintf(eos(message), "(%c) ", def);
(void)strncpy(message, question, QBUFSZ-1);
message[QBUFSZ-1] = '\0';
sprintf(eos(message), " [%s]", choicebuf);
if (def) sprintf(eos(message), " (%c)", def);
Strcat(message, " ");
/* escape maps to 'q' or 'n' or default, in that order */
yn_esc_map = (index(choices, 'q') ? 'q' :
(index(choices, 'n') ? 'n' : def));