mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 14:03:58 +00:00
Tighten up support_term256 logic. Add missing Apple_Terminal underscore
Add some debug output like there is for 24bit mode. I see now there is no need to setup terminal here - we get called early sometimes for colors to work in config.fish to work but that is not so fatal. Just check cur_term and trust get called again soon.
This commit is contained in:
parent
34ca8fd213
commit
3468fbc605
1 changed files with 25 additions and 21 deletions
|
@ -301,40 +301,43 @@ static int interrupt_handler() {
|
||||||
|
|
||||||
void update_fish_color_support(void) {
|
void update_fish_color_support(void) {
|
||||||
// Detect or infer term256 support. If fish_term256 is set, we respect it;
|
// Detect or infer term256 support. If fish_term256 is set, we respect it;
|
||||||
// otherwise try to detect terminfo else infer it from the TERM variable.
|
// otherwise infer it from the TERM variable or use terminfo.
|
||||||
env_var_t fish_term256 = env_get_string(L"fish_term256");
|
env_var_t fish_term256 = env_get_string(L"fish_term256");
|
||||||
bool support_term256;
|
env_var_t term = env_get_string(L"TERM");
|
||||||
|
bool support_term256 = false; // default to no support
|
||||||
if (!fish_term256.missing_or_empty()) {
|
if (!fish_term256.missing_or_empty()) {
|
||||||
support_term256 = from_string<bool>(fish_term256);
|
support_term256 = from_string<bool>(fish_term256);
|
||||||
} else {
|
} else if (term.find(L"256color") != wcstring::npos) {
|
||||||
env_var_t term = env_get_string(L"TERM");
|
// *256color*: Explicitly supported.
|
||||||
if (term.missing()) {
|
support_term256 = true;
|
||||||
support_term256 = false;
|
} else if (term.find(L"xterm") != wcstring::npos) {
|
||||||
} else if (term.find(L"256color") != wcstring::npos) {
|
// Assume that all xterms are 256, except for OS X SnowLeopard
|
||||||
// Explicitly supported.
|
const env_var_t prog = env_get_string(L"TERM_PROGRAM");
|
||||||
support_term256 = true;
|
const env_var_t progver = env_get_string(L"TERM_PROGRAM_VERSION");
|
||||||
} else if (term.find(L"xterm") != wcstring::npos) {
|
if (prog == L"Apple_Terminal" && !progver.missing_or_empty()) {
|
||||||
// Assume that all xterms are 256, except for OS X SnowLeopard
|
// SL and earlier don't getOS X Lion is 300+
|
||||||
const env_var_t prog = env_get_string(L"TERM_PROGRAM");
|
if (strtod(wcs2str(progver), NULL) > 300) {
|
||||||
const env_var_t progver = env_get_string(L"TERM_PROGRAM_VERSION");
|
|
||||||
if (progver.missing_or_empty()) {
|
|
||||||
support_term256 = true;
|
support_term256 = true;
|
||||||
} else { // OS X Lion is 300+
|
debug(2, L"modern Terminal.app with TERM=xterm - assuming term256 support");
|
||||||
support_term256 =
|
|
||||||
(prog != L"Apple_Terminal" || strtod(wcs2str(progver), NULL) > 300);
|
|
||||||
}
|
}
|
||||||
// See if terminfo happens to identify 256 colors, else default to false.
|
|
||||||
} else if (setupterm(NULL, STDOUT_FILENO, NULL) != ERR) {
|
|
||||||
support_term256 = (max_colors >= 256);
|
|
||||||
} else {
|
} else {
|
||||||
support_term256 = false;
|
support_term256 = true;
|
||||||
|
debug(2, "TERM=xterm - assuming term256 support");
|
||||||
}
|
}
|
||||||
|
} else if (cur_term != NULL) {
|
||||||
|
// See if terminfo happens to identify 256 colors
|
||||||
|
support_term256 = (max_colors >= 256);
|
||||||
|
debug(2, "term256 check: using %d colors per terminfo", max_colors);
|
||||||
|
} else {
|
||||||
|
debug(2, "term256 check not turning on (yet)");
|
||||||
}
|
}
|
||||||
|
|
||||||
env_var_t fish_term24bit = env_get_string(L"fish_term24bit");
|
env_var_t fish_term24bit = env_get_string(L"fish_term24bit");
|
||||||
bool support_term24bit;
|
bool support_term24bit;
|
||||||
if (!fish_term24bit.missing_or_empty()) {
|
if (!fish_term24bit.missing_or_empty()) {
|
||||||
support_term24bit = from_string<bool>(fish_term24bit);
|
support_term24bit = from_string<bool>(fish_term24bit);
|
||||||
|
debug(2, "'fish_term24bit' preference: 24-bit color %s",
|
||||||
|
support_term24bit ? "enabled" : "disabled");
|
||||||
} else {
|
} else {
|
||||||
// We don't attempt to infer term24 bit support yet.
|
// We don't attempt to infer term24 bit support yet.
|
||||||
support_term24bit = false;
|
support_term24bit = false;
|
||||||
|
@ -369,6 +372,7 @@ int input_init() {
|
||||||
} else {
|
} else {
|
||||||
debug(0, _(L"Using fallback terminal type '%ls'"), DEFAULT_TERM);
|
debug(0, _(L"Using fallback terminal type '%ls'"), DEFAULT_TERM);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
}
|
}
|
||||||
|
|
||||||
input_terminfo_init();
|
input_terminfo_init();
|
||||||
|
|
Loading…
Reference in a new issue