lineedit: limit ASK_TERMINAL to the case when we can't find out the width

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2010-07-18 22:53:06 +02:00
parent b9e35dc15d
commit 55241fa2e0

View File

@ -149,6 +149,7 @@ struct lineedit_statics {
CHAR_T delbuf[DELBUFSIZ]; /* a place to store deleted characters */
#endif
#if ENABLE_FEATURE_EDITING_ASK_TERMINAL
smallint unknown_width;
smallint sent_ESC_br6n;
#endif
@ -1610,6 +1611,7 @@ static void ask_terminal(void)
* poll([{fd=0, events=POLLIN}], 1, 4294967295) = 1 ([{fd=0, revents=POLLIN}])
* read(0, "\n", 1) = 1 <-- oh crap, user's input got in first
*/
if (S.unknown_width) { /* only if window size is not known */
struct pollfd pfd;
pfd.fd = STDIN_FILENO;
@ -1619,6 +1621,7 @@ static void ask_terminal(void)
fputs("\033" "[6n", stdout);
fflush_all(); /* make terminal see it ASAP! */
}
}
}
#else
#define ask_terminal() ((void)0)
@ -1763,11 +1766,13 @@ static void cmdedit_setwidth(unsigned w, int redraw_flg)
static void win_changed(int nsig)
{
int sv_errno = errno;
unsigned width;
get_terminal_width_height(0, &width, NULL);
IF_FEATURE_EDITING_ASK_TERMINAL(S.unknown_width =) get_terminal_width_height(0, &width, NULL);
cmdedit_setwidth(width, nsig /* - just a yes/no flag */);
if (nsig == SIGWINCH)
signal(SIGWINCH, win_changed); /* rearm ourself */
errno = sv_errno;
}
static int lineedit_read_key(char *read_key_buffer)