fix(colors): send full style reset in diff (#32)

This commit is contained in:
Aram Drevekenin 2020-11-09 18:53:22 +01:00 committed by GitHub
parent f02136ec0d
commit b876843adf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -153,6 +153,32 @@ impl CharacterStyles {
} }
pub fn update_and_return_diff(&mut self, new_styles: &CharacterStyles) -> Option<CharacterStyles> { pub fn update_and_return_diff(&mut self, new_styles: &CharacterStyles) -> Option<CharacterStyles> {
let mut diff: Option<CharacterStyles> = None; let mut diff: Option<CharacterStyles> = None;
if new_styles.foreground == Some(AnsiCode::Reset) &&
new_styles.background == Some(AnsiCode::Reset) &&
new_styles.strike == Some(AnsiCode::Reset) &&
new_styles.hidden == Some(AnsiCode::Reset) &&
new_styles.reverse == Some(AnsiCode::Reset) &&
new_styles.fast_blink == Some(AnsiCode::Reset) &&
new_styles.slow_blink == Some(AnsiCode::Reset) &&
new_styles.underline == Some(AnsiCode::Reset) &&
new_styles.bold == Some(AnsiCode::Reset) &&
new_styles.dim == Some(AnsiCode::Reset) &&
new_styles.italic == Some(AnsiCode::Reset) {
self.foreground = Some(AnsiCode::Reset);
self.background = Some(AnsiCode::Reset);
self.strike = Some(AnsiCode::Reset);
self.hidden = Some(AnsiCode::Reset);
self.reverse = Some(AnsiCode::Reset);
self.fast_blink = Some(AnsiCode::Reset);
self.slow_blink = Some(AnsiCode::Reset);
self.underline = Some(AnsiCode::Reset);
self.bold = Some(AnsiCode::Reset);
self.dim = Some(AnsiCode::Reset);
self.italic = Some(AnsiCode::Reset);
return Some(*new_styles)
};
if self.foreground != new_styles.foreground { if self.foreground != new_styles.foreground {
if let Some(new_diff) = diff.as_mut() { if let Some(new_diff) = diff.as_mut() {
diff = Some(new_diff.foreground(new_styles.foreground)); diff = Some(new_diff.foreground(new_styles.foreground));