mirror of
https://github.com/tmux/tmux.git
synced 2025-04-05 07:38:49 +00:00
Sync OpenBSD patchset 1006:
Add strings to allow the aixterm bright colours to be used when configuring colours, requested by Elliott Cable a few months ago.
This commit is contained in:
parent
cc967ffeb9
commit
d4c2a935f2
40
colour.c
40
colour.c
@ -170,6 +170,22 @@ colour_tostring(int c)
|
|||||||
return ("white");
|
return ("white");
|
||||||
case 8:
|
case 8:
|
||||||
return ("default");
|
return ("default");
|
||||||
|
case 90:
|
||||||
|
return ("brightblack");
|
||||||
|
case 91:
|
||||||
|
return ("brightred");
|
||||||
|
case 92:
|
||||||
|
return ("brightgreen");
|
||||||
|
case 93:
|
||||||
|
return ("brightyellow");
|
||||||
|
case 94:
|
||||||
|
return ("brightblue");
|
||||||
|
case 95:
|
||||||
|
return ("brightmagenta");
|
||||||
|
case 96:
|
||||||
|
return ("brightcyan");
|
||||||
|
case 97:
|
||||||
|
return ("brightwhite");
|
||||||
}
|
}
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -219,6 +235,30 @@ colour_fromstring(const char *s)
|
|||||||
return (7);
|
return (7);
|
||||||
if (strcasecmp(s, "default") == 0 || (s[0] == '8' && s[1] == '\0'))
|
if (strcasecmp(s, "default") == 0 || (s[0] == '8' && s[1] == '\0'))
|
||||||
return (8);
|
return (8);
|
||||||
|
if (strcasecmp(s, "brightblack") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '0' && s[1] == '\0'))
|
||||||
|
return (90);
|
||||||
|
if (strcasecmp(s, "brightred") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '1' && s[1] == '\0'))
|
||||||
|
return (91);
|
||||||
|
if (strcasecmp(s, "brightgreen") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '2' && s[1] == '\0'))
|
||||||
|
return (92);
|
||||||
|
if (strcasecmp(s, "brightyellow") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '3' && s[1] == '\0'))
|
||||||
|
return (93);
|
||||||
|
if (strcasecmp(s, "brightblue") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '4' && s[1] == '\0'))
|
||||||
|
return (94);
|
||||||
|
if (strcasecmp(s, "brightmagenta") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '5' && s[1] == '\0'))
|
||||||
|
return (95);
|
||||||
|
if (strcasecmp(s, "brightcyan") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '6' && s[1] == '\0'))
|
||||||
|
return (96);
|
||||||
|
if (strcasecmp(s, "brightwhite") == 0 ||
|
||||||
|
(s[0] == '9' && s[1] == '7' && s[1] == '\0'))
|
||||||
|
return (97);
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
input.c
2
input.c
@ -1436,7 +1436,7 @@ input_csi_dispatch_sgr(struct input_ctx *ictx)
|
|||||||
case 106:
|
case 106:
|
||||||
case 107:
|
case 107:
|
||||||
gc->flags &= ~GRID_FLAG_BG256;
|
gc->flags &= ~GRID_FLAG_BG256;
|
||||||
gc->bg = n;
|
gc->bg = n - 10;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
4
tmux.1
4
tmux.1
@ -1980,6 +1980,10 @@ is one of:
|
|||||||
.Ic magenta ,
|
.Ic magenta ,
|
||||||
.Ic cyan ,
|
.Ic cyan ,
|
||||||
.Ic white ,
|
.Ic white ,
|
||||||
|
aixterm bright variants (if supported:
|
||||||
|
.Ic brightred ,
|
||||||
|
.Ic brightgreen ,
|
||||||
|
and so on),
|
||||||
.Ic colour0
|
.Ic colour0
|
||||||
to
|
to
|
||||||
.Ic colour255
|
.Ic colour255
|
||||||
|
8
tty.c
8
tty.c
@ -1440,7 +1440,7 @@ tty_check_bg(struct tty *tty, struct grid_cell *gc)
|
|||||||
|
|
||||||
/* Is this an aixterm colour? */
|
/* Is this an aixterm colour? */
|
||||||
colours = tty_term_number(tty->term, TTYC_COLORS);
|
colours = tty_term_number(tty->term, TTYC_COLORS);
|
||||||
if (gc->bg >= 100 && gc->bg <= 107 && colours < 16) {
|
if (gc->bg >= 90 && gc->bg <= 97 && colours < 16) {
|
||||||
gc->bg -= 90;
|
gc->bg -= 90;
|
||||||
gc->attr |= GRID_ATTR_BRIGHT;
|
gc->attr |= GRID_ATTR_BRIGHT;
|
||||||
}
|
}
|
||||||
@ -1500,14 +1500,14 @@ tty_colours_bg(struct tty *tty, const struct grid_cell *gc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Is this an aixterm bright colour? */
|
/* Is this an aixterm bright colour? */
|
||||||
if (bg >= 100 && bg <= 107) {
|
if (bg >= 90 && bg <= 97) {
|
||||||
/* 16 colour terminals or above only. */
|
/* 16 colour terminals or above only. */
|
||||||
if (tty_term_number(tty->term, TTYC_COLORS) >= 16) {
|
if (tty_term_number(tty->term, TTYC_COLORS) >= 16) {
|
||||||
xsnprintf(s, sizeof s, "\033[%dm", bg);
|
xsnprintf(s, sizeof s, "\033[%dm", bg + 10);
|
||||||
tty_puts(tty, s);
|
tty_puts(tty, s);
|
||||||
goto save_bg;
|
goto save_bg;
|
||||||
}
|
}
|
||||||
bg -= 100;
|
bg -= 90;
|
||||||
/* no such thing as a bold background */
|
/* no such thing as a bold background */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user