Merge branch 'js/stop-exporting-bogus-columns'
When we cannot figure out how wide the terminal is, we use a fallback value of 80 ourselves (which cannot be avoided), but when we run the pager, we export it in COLUMNS, which forces the pager to use the hardcoded value, even when the pager is perfectly capable to figure it out itself. Stop exporting COLUMNS when we fall back on the hardcoded default value for our own use. * js/stop-exporting-bogus-columns: pager: avoid setting COLUMNS when we're guessing its value
This commit is contained in:
commit
32d6280226
14
pager.c
14
pager.c
@ -11,6 +11,10 @@
|
|||||||
static struct child_process pager_process = CHILD_PROCESS_INIT;
|
static struct child_process pager_process = CHILD_PROCESS_INIT;
|
||||||
static const char *pager_program;
|
static const char *pager_program;
|
||||||
|
|
||||||
|
/* Is the value coming back from term_columns() just a guess? */
|
||||||
|
static int term_columns_guessed;
|
||||||
|
|
||||||
|
|
||||||
static void close_pager_fds(void)
|
static void close_pager_fds(void)
|
||||||
{
|
{
|
||||||
/* signal EOF to pager */
|
/* signal EOF to pager */
|
||||||
@ -114,6 +118,7 @@ void setup_pager(void)
|
|||||||
{
|
{
|
||||||
char buf[64];
|
char buf[64];
|
||||||
xsnprintf(buf, sizeof(buf), "%d", term_columns());
|
xsnprintf(buf, sizeof(buf), "%d", term_columns());
|
||||||
|
if (!term_columns_guessed)
|
||||||
setenv("COLUMNS", buf, 0);
|
setenv("COLUMNS", buf, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -158,15 +163,20 @@ int term_columns(void)
|
|||||||
return term_columns_at_startup;
|
return term_columns_at_startup;
|
||||||
|
|
||||||
term_columns_at_startup = 80;
|
term_columns_at_startup = 80;
|
||||||
|
term_columns_guessed = 1;
|
||||||
|
|
||||||
col_string = getenv("COLUMNS");
|
col_string = getenv("COLUMNS");
|
||||||
if (col_string && (n_cols = atoi(col_string)) > 0)
|
if (col_string && (n_cols = atoi(col_string)) > 0) {
|
||||||
term_columns_at_startup = n_cols;
|
term_columns_at_startup = n_cols;
|
||||||
|
term_columns_guessed = 0;
|
||||||
|
}
|
||||||
#ifdef TIOCGWINSZ
|
#ifdef TIOCGWINSZ
|
||||||
else {
|
else {
|
||||||
struct winsize ws;
|
struct winsize ws;
|
||||||
if (!ioctl(1, TIOCGWINSZ, &ws) && ws.ws_col)
|
if (!ioctl(1, TIOCGWINSZ, &ws) && ws.ws_col) {
|
||||||
term_columns_at_startup = ws.ws_col;
|
term_columns_at_startup = ws.ws_col;
|
||||||
|
term_columns_guessed = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user