Detect WezTerm and mark it as undercurl/Smulx capable

This commit is contained in:
Blaž Hrastnik 2022-12-02 17:42:10 +09:00
parent e92651816d
commit 98c121c9fc
No known key found for this signature in database
GPG Key ID: 1238B9C4AD889640

View File

@ -14,6 +14,10 @@ use std::{
fmt, fmt,
io::{self, Write}, io::{self, Write},
}; };
fn term_program() -> Option<String> {
std::env::var("TERM_PROGRAM").ok()
}
fn vte_version() -> Option<usize> { fn vte_version() -> Option<usize> {
std::env::var("VTE_VERSION").ok()?.parse().ok() std::env::var("VTE_VERSION").ok()?.parse().ok()
} }
@ -35,9 +39,11 @@ impl Capabilities {
Ok(t) => Capabilities { Ok(t) => Capabilities {
// Smulx, VTE: https://unix.stackexchange.com/a/696253/246284 // Smulx, VTE: https://unix.stackexchange.com/a/696253/246284
// Su (used by kitty): https://sw.kovidgoyal.net/kitty/underlines // Su (used by kitty): https://sw.kovidgoyal.net/kitty/underlines
// WezTerm supports underlines but a lot of distros don't properly install it's terminfo
has_extended_underlines: t.extended_cap("Smulx").is_some() has_extended_underlines: t.extended_cap("Smulx").is_some()
|| t.extended_cap("Su").is_some() || t.extended_cap("Su").is_some()
|| vte_version() >= Some(5102), || vte_version() >= Some(5102)
|| matches!(term_program().as_deref(), Some("WezTerm")),
}, },
} }
} }