Merge branch 'obsd-master'

This commit is contained in:
Thomas Adam 2018-10-25 17:02:42 +01:00
commit e771f10dc6
7 changed files with 51 additions and 32 deletions

View File

@ -141,6 +141,8 @@ colour_tostring(int c)
return ("white"); return ("white");
case 8: case 8:
return ("default"); return ("default");
case 9:
return ("terminal");
case 90: case 90:
return ("brightblack"); return ("brightblack");
case 91: case 91:
@ -188,6 +190,11 @@ colour_fromstring(const char *s)
return (n | COLOUR_FLAG_256); return (n | COLOUR_FLAG_256);
} }
if (strcasecmp(s, "default") == 0)
return (8);
if (strcasecmp(s, "terminal") == 0)
return (9);
if (strcasecmp(s, "black") == 0 || strcmp(s, "0") == 0) if (strcasecmp(s, "black") == 0 || strcmp(s, "0") == 0)
return (0); return (0);
if (strcasecmp(s, "red") == 0 || strcmp(s, "1") == 0) if (strcasecmp(s, "red") == 0 || strcmp(s, "1") == 0)
@ -204,8 +211,6 @@ colour_fromstring(const char *s)
return (6); return (6);
if (strcasecmp(s, "white") == 0 || strcmp(s, "7") == 0) if (strcasecmp(s, "white") == 0 || strcmp(s, "7") == 0)
return (7); return (7);
if (strcasecmp(s, "default") == 0 || strcmp(s, "8") == 0)
return (8);
if (strcasecmp(s, "brightblack") == 0 || strcmp(s, "90") == 0) if (strcasecmp(s, "brightblack") == 0 || strcmp(s, "90") == 0)
return (90); return (90);
if (strcasecmp(s, "brightred") == 0 || strcmp(s, "91") == 0) if (strcasecmp(s, "brightred") == 0 || strcmp(s, "91") == 0)

14
grid.c
View File

@ -418,7 +418,7 @@ static void
grid_empty_line(struct grid *gd, u_int py, u_int bg) grid_empty_line(struct grid *gd, u_int py, u_int bg)
{ {
memset(&gd->linedata[py], 0, sizeof gd->linedata[py]); memset(&gd->linedata[py], 0, sizeof gd->linedata[py]);
if (bg != 8) if (!COLOUR_DEFAULT(bg))
grid_expand_line(gd, py, gd->sx, bg); grid_expand_line(gd, py, gd->sx, bg);
} }
@ -524,6 +524,7 @@ grid_set_cells(struct grid *gd, u_int px, u_int py, const struct grid_cell *gc,
void void
grid_clear(struct grid *gd, u_int px, u_int py, u_int nx, u_int ny, u_int bg) grid_clear(struct grid *gd, u_int px, u_int py, u_int nx, u_int ny, u_int bg)
{ {
struct grid_line *gl;
u_int xx, yy; u_int xx, yy;
if (nx == 0 || ny == 0) if (nx == 0 || ny == 0)
@ -540,12 +541,13 @@ grid_clear(struct grid *gd, u_int px, u_int py, u_int nx, u_int ny, u_int bg)
return; return;
for (yy = py; yy < py + ny; yy++) { for (yy = py; yy < py + ny; yy++) {
if (px + nx >= gd->sx && px < gd->linedata[yy].cellused) gl = &gd->linedata[yy];
gd->linedata[yy].cellused = px; if (px + nx >= gd->sx && px < gl->cellused)
if (px > gd->linedata[yy].cellsize && bg == 8) gl->cellused = px;
if (px > gl->cellsize && COLOUR_DEFAULT(bg))
continue; continue;
if (px + nx >= gd->linedata[yy].cellsize && bg == 8) { if (px + nx >= gl->cellsize && COLOUR_DEFAULT(bg)) {
gd->linedata[yy].cellsize = px; gl->cellsize = px;
continue; continue;
} }
grid_expand_line(gd, yy, px + nx, 8); /* default bg first */ grid_expand_line(gd, yy, px + nx, 8); /* default bg first */

View File

@ -770,7 +770,7 @@ const struct options_table_entry options_table[] = {
.type = OPTIONS_TABLE_CHOICE, .type = OPTIONS_TABLE_CHOICE,
.scope = OPTIONS_TABLE_WINDOW, .scope = OPTIONS_TABLE_WINDOW,
.choices = options_table_window_size_list, .choices = options_table_window_size_list,
.default_num = WINDOW_SIZE_LARGEST .default_num = WINDOW_SIZE_SMALLEST
}, },
{ .name = "window-style", { .name = "window-style",

View File

@ -965,7 +965,7 @@ screen_write_clearline(struct screen_write_ctx *ctx, u_int bg)
u_int sx = screen_size_x(s); u_int sx = screen_size_x(s);
gl = grid_get_line(s->grid, s->grid->hsize + s->cy); gl = grid_get_line(s->grid, s->grid->hsize + s->cy);
if (gl->cellsize == 0 && bg == 8) if (gl->cellsize == 0 && COLOUR_DEFAULT(bg))
return; return;
screen_write_initctx(ctx, &ttyctx); screen_write_initctx(ctx, &ttyctx);
@ -988,7 +988,7 @@ screen_write_clearendofline(struct screen_write_ctx *ctx, u_int bg)
u_int sx = screen_size_x(s); u_int sx = screen_size_x(s);
gl = grid_get_line(s->grid, s->grid->hsize + s->cy); gl = grid_get_line(s->grid, s->grid->hsize + s->cy);
if (s->cx > sx - 1 || (s->cx >= gl->cellsize && bg == 8)) if (s->cx > sx - 1 || (s->cx >= gl->cellsize && COLOUR_DEFAULT(bg)))
return; return;
screen_write_initctx(ctx, &ttyctx); screen_write_initctx(ctx, &ttyctx);

11
tmux.1
View File

@ -2837,7 +2837,7 @@ Set status line message command style, where
.Ar style .Ar style
is a comma-separated list of characteristics to be specified. is a comma-separated list of characteristics to be specified.
.Pp .Pp
These may be The style format is shared by many options and may be:
.Ql bg=colour .Ql bg=colour
to set the background colour, to set the background colour,
.Ql fg=colour .Ql fg=colour
@ -2860,8 +2860,13 @@ and so on),
to to
.Ic colour255 .Ic colour255
from the 256-colour set, from the 256-colour set,
.Ic default , .Ic default
or a hexadecimal RGB string such as for the default colour (inherited from another option in the case of some options, for example
.Ic window-status-style
inherits from
.Ic status-style ) ,
.Ic terminal
for the terminal default colour, or a hexadecimal RGB string such as
.Ql #ffffff . .Ql #ffffff .
.Pp .Pp
The attributes is either The attributes is either

3
tmux.h
View File

@ -545,6 +545,9 @@ enum utf8_state {
#define COLOUR_FLAG_256 0x01000000 #define COLOUR_FLAG_256 0x01000000
#define COLOUR_FLAG_RGB 0x02000000 #define COLOUR_FLAG_RGB 0x02000000
/* Special colours. */
#define COLOUR_DEFAULT(c) ((c) == 8 || (c) == 9)
/* Grid attributes. Anything above 0xff is stored in an extended cell. */ /* Grid attributes. Anything above 0xff is stored in an extended cell. */
#define GRID_ATTR_BRIGHT 0x1 #define GRID_ATTR_BRIGHT 0x1
#define GRID_ATTR_DIM 0x2 #define GRID_ATTR_DIM 0x2

34
tty.c
View File

@ -851,7 +851,7 @@ tty_fake_bce(const struct tty *tty, const struct window_pane *wp, u_int bg)
if (wp != NULL) if (wp != NULL)
tty_default_colours(&gc, wp); tty_default_colours(&gc, wp);
if (bg != 8 || gc.bg != 8) if (!COLOUR_DEFAULT(bg) || !COLOUR_DEFAULT(gc.bg))
return (1); return (1);
return (0); return (0);
} }
@ -1098,7 +1098,7 @@ tty_clear_area(struct tty *tty, const struct window_pane *wp, u_int py,
* background colour isn't default (because it doesn't work * background colour isn't default (because it doesn't work
* after SGR 0). * after SGR 0).
*/ */
if (tty->term_type == TTY_VT420 && bg != 8) { if (tty->term_type == TTY_VT420 && COLOUR_DEFAULT(bg)) {
xsnprintf(tmp, sizeof tmp, "\033[32;%u;%u;%u;%u$x", xsnprintf(tmp, sizeof tmp, "\033[32;%u;%u;%u;%u$x",
py + 1, px + 1, py + ny, px + nx); py + 1, px + 1, py + ny, px + nx);
tty_puts(tty, tmp); tty_puts(tty, tmp);
@ -2134,10 +2134,10 @@ tty_attributes(struct tty *tty, const struct grid_cell *gc,
*/ */
if (!tty_term_has(tty->term, TTYC_SETAB)) { if (!tty_term_has(tty->term, TTYC_SETAB)) {
if (gc2.attr & GRID_ATTR_REVERSE) { if (gc2.attr & GRID_ATTR_REVERSE) {
if (gc2.fg != 7 && gc2.fg != 8) if (gc2.fg != 7 && !COLOUR_DEFAULT(gc2.fg))
gc2.attr &= ~GRID_ATTR_REVERSE; gc2.attr &= ~GRID_ATTR_REVERSE;
} else { } else {
if (gc2.bg != 0 && gc2.bg != 8) if (gc2.bg != 0 && !COLOUR_DEFAULT(gc2.bg))
gc2.attr |= GRID_ATTR_REVERSE; gc2.attr |= GRID_ATTR_REVERSE;
} }
} }
@ -2212,7 +2212,7 @@ tty_colours(struct tty *tty, const struct grid_cell *gc)
* case if only one is default need to fall onward to set the other * case if only one is default need to fall onward to set the other
* colour. * colour.
*/ */
if (gc->fg == 8 || gc->bg == 8) { if (COLOUR_DEFAULT(gc->fg) || COLOUR_DEFAULT(gc->bg)) {
/* /*
* If don't have AX but do have op, send sgr0 (op can't * If don't have AX but do have op, send sgr0 (op can't
* actually be used because it is sometimes the same as sgr0 * actually be used because it is sometimes the same as sgr0
@ -2224,32 +2224,32 @@ tty_colours(struct tty *tty, const struct grid_cell *gc)
if (!have_ax && tty_term_has(tty->term, TTYC_OP)) if (!have_ax && tty_term_has(tty->term, TTYC_OP))
tty_reset(tty); tty_reset(tty);
else { else {
if (gc->fg == 8 && tc->fg != 8) { if (COLOUR_DEFAULT(gc->fg) && !COLOUR_DEFAULT(tc->fg)) {
if (have_ax) if (have_ax)
tty_puts(tty, "\033[39m"); tty_puts(tty, "\033[39m");
else if (tc->fg != 7) else if (tc->fg != 7)
tty_putcode1(tty, TTYC_SETAF, 7); tty_putcode1(tty, TTYC_SETAF, 7);
tc->fg = 8; tc->fg = gc->fg;
} }
if (gc->bg == 8 && tc->bg != 8) { if (COLOUR_DEFAULT(gc->bg) && !COLOUR_DEFAULT(tc->bg)) {
if (have_ax) if (have_ax)
tty_puts(tty, "\033[49m"); tty_puts(tty, "\033[49m");
else if (tc->bg != 0) else if (tc->bg != 0)
tty_putcode1(tty, TTYC_SETAB, 0); tty_putcode1(tty, TTYC_SETAB, 0);
tc->bg = 8; tc->bg = gc->fg;
} }
} }
} }
/* Set the foreground colour. */ /* Set the foreground colour. */
if (gc->fg != 8 && gc->fg != tc->fg) if (!COLOUR_DEFAULT(gc->fg) && gc->fg != tc->fg)
tty_colours_fg(tty, gc); tty_colours_fg(tty, gc);
/* /*
* Set the background colour. This must come after the foreground as * Set the background colour. This must come after the foreground as
* tty_colour_fg() can call tty_reset(). * tty_colour_fg() can call tty_reset().
*/ */
if (gc->bg != 8 && gc->bg != tc->bg) if (!COLOUR_DEFAULT(gc->bg) && gc->bg != tc->bg)
tty_colours_bg(tty, gc); tty_colours_bg(tty, gc);
} }
@ -2515,10 +2515,12 @@ tty_default_colours(struct grid_cell *gc, const struct window_pane *wp)
else else
gc->fg = wgc->fg; gc->fg = wgc->fg;
if (gc->fg != 8 && if (gc->fg != 8) {
(c = window_pane_get_palette(wp, gc->fg)) != -1) c = window_pane_get_palette(wp, gc->fg);
if (c != -1)
gc->fg = c; gc->fg = c;
} }
}
if (gc->bg == 8) { if (gc->bg == 8) {
if (pgc->bg != 8) if (pgc->bg != 8)
@ -2528,10 +2530,12 @@ tty_default_colours(struct grid_cell *gc, const struct window_pane *wp)
else else
gc->bg = wgc->bg; gc->bg = wgc->bg;
if (gc->bg != 8 && if (gc->bg != 8) {
(c = window_pane_get_palette(wp, gc->bg)) != -1) c = window_pane_get_palette(wp, gc->bg);
if (c != -1)
gc->bg = c; gc->bg = c;
} }
}
} }
static void static void