From 9a826b2186fb697b7c7498cb560ef604785ca508 Mon Sep 17 00:00:00 2001 From: kennytm Date: Sun, 11 Nov 2018 15:44:13 +0800 Subject: [PATCH 1/2] Support the first 16 Ansi256 colors on Windows --- src/lib.rs | 57 +++++++++++++++++++++++++++++++++--------------------- 1 file changed, 35 insertions(+), 22 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 1e9cef0..b062a28 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1511,17 +1511,10 @@ impl ColorSpec { &self, console: &mut wincolor::Console, ) -> io::Result<()> { - use wincolor::Intense; - - let intense = if self.intense { Intense::Yes } else { Intense::No }; - - let fg_color = self.fg_color.as_ref().and_then(|c| c.to_windows()); - if let Some(color) = fg_color { + if let Some((intense, color)) = self.fg_color.and_then(|c| c.to_windows(self.intense)) { console.fg(intense, color)?; } - - let bg_color = self.bg_color.as_ref().and_then(|c| c.to_windows()); - if let Some(color) = bg_color { + if let Some((intense, color)) = self.bg_color.and_then(|c| c.to_windows(self.intense)) { console.bg(intense, color)?; } Ok(()) @@ -1569,20 +1562,40 @@ pub enum Color { impl Color { /// Translate this color to a wincolor::Color. #[cfg(windows)] - fn to_windows(&self) -> Option { - match *self { - Color::Black => Some(wincolor::Color::Black), - Color::Blue => Some(wincolor::Color::Blue), - Color::Green => Some(wincolor::Color::Green), - Color::Red => Some(wincolor::Color::Red), - Color::Cyan => Some(wincolor::Color::Cyan), - Color::Magenta => Some(wincolor::Color::Magenta), - Color::Yellow => Some(wincolor::Color::Yellow), - Color::White => Some(wincolor::Color::White), - Color::Ansi256(_) => None, - Color::Rgb(_, _, _) => None, + fn to_windows(self, intense: bool) -> Option<(wincolor::Intense, wincolor::Color)> { + use wincolor::Intense::{Yes, No}; + + let color = match self { + Color::Black => wincolor::Color::Black, + Color::Blue => wincolor::Color::Blue, + Color::Green => wincolor::Color::Green, + Color::Red => wincolor::Color::Red, + Color::Cyan => wincolor::Color::Cyan, + Color::Magenta => wincolor::Color::Magenta, + Color::Yellow => wincolor::Color::Yellow, + Color::White => wincolor::Color::White, + Color::Ansi256(0) => return Some((No, wincolor::Color::Black)), + Color::Ansi256(1) => return Some((No, wincolor::Color::Red)), + Color::Ansi256(2) => return Some((No, wincolor::Color::Green)), + Color::Ansi256(3) => return Some((No, wincolor::Color::Yellow)), + Color::Ansi256(4) => return Some((No, wincolor::Color::Blue)), + Color::Ansi256(5) => return Some((No, wincolor::Color::Magenta)), + Color::Ansi256(6) => return Some((No, wincolor::Color::Cyan)), + Color::Ansi256(7) => return Some((No, wincolor::Color::White)), + Color::Ansi256(8) => return Some((Yes, wincolor::Color::Black)), + Color::Ansi256(9) => return Some((Yes, wincolor::Color::Red)), + Color::Ansi256(10) => return Some((Yes, wincolor::Color::Green)), + Color::Ansi256(11) => return Some((Yes, wincolor::Color::Yellow)), + Color::Ansi256(12) => return Some((Yes, wincolor::Color::Blue)), + Color::Ansi256(13) => return Some((Yes, wincolor::Color::Magenta)), + Color::Ansi256(14) => return Some((Yes, wincolor::Color::Cyan)), + Color::Ansi256(15) => return Some((Yes, wincolor::Color::White)), + Color::Ansi256(_) => return None, + Color::Rgb(_, _, _) => return None, Color::__Nonexhaustive => unreachable!(), - } + }; + let intense = if intense { Yes } else { No }; + Some((intense, color)) } /// Parses a numeric color string, either ANSI or RGB. From f968d3700e731d03a125ef051822d62bd83e0c41 Mon Sep 17 00:00:00 2001 From: kennytm Date: Tue, 4 Jun 2019 21:39:03 +0800 Subject: [PATCH 2/2] Keep line length below 79 characters --- src/lib.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index b062a28..f220b59 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1511,10 +1511,12 @@ impl ColorSpec { &self, console: &mut wincolor::Console, ) -> io::Result<()> { - if let Some((intense, color)) = self.fg_color.and_then(|c| c.to_windows(self.intense)) { + let fg_color = self.fg_color.and_then(|c| c.to_windows(self.intense)); + if let Some((intense, color)) = fg_color { console.fg(intense, color)?; } - if let Some((intense, color)) = self.bg_color.and_then(|c| c.to_windows(self.intense)) { + let bg_color = self.bg_color.and_then(|c| c.to_windows(self.intense)); + if let Some((intense, color)) = bg_color { console.bg(intense, color)?; } Ok(()) @@ -1562,7 +1564,10 @@ pub enum Color { impl Color { /// Translate this color to a wincolor::Color. #[cfg(windows)] - fn to_windows(self, intense: bool) -> Option<(wincolor::Intense, wincolor::Color)> { + fn to_windows( + self, + intense: bool, + ) -> Option<(wincolor::Intense, wincolor::Color)> { use wincolor::Intense::{Yes, No}; let color = match self {