use std::io;
use std::io::Write;
use termcolor::{Color, ColorChoice, ColorSpec, StandardStream, WriteColor};
use crate::config::ColorMode;
use crate::status::Status;
#[derive(Debug)]
pub struct ColorHarness {
color_choice: ColorChoice,
}
impl ColorHarness {
pub fn new(color_mode: ColorMode) -> Self {
Self {
color_choice: match &color_mode {
ColorMode::Always => ColorChoice::Always,
ColorMode::Compatibility => ColorChoice::Auto,
ColorMode::Never => ColorChoice::Never,
},
}
}
pub fn write_status(&self, status: Status, status_width: usize) -> io::Result<()> {
let mut stdout = StandardStream::stdout(self.color_choice);
stdout.set_color(ColorSpec::new().set_fg(Some(match status {
Status::Bare | Status::Unknown => Color::Red,
Status::Clean => Color::Green,
Status::Unpushed => Color::Blue,
Status::Unclean => Color::Yellow,
})))?;
write!(
&mut stdout,
"{:<status_width$}",
status.as_str(),
status_width = status_width,
)?;
stdout.reset()
}
pub fn write_bold(&self, input: &str, newline: bool) -> io::Result<()> {
self.write_color(input, newline, ColorSpec::new().set_bold(true))
}
pub fn write_gray(&self, input: &str, newline: bool) -> io::Result<()> {
self.write_color(
input,
newline,
ColorSpec::new().set_fg(Some(match &self.color_choice {
ColorChoice::Auto => Color::Cyan,
_ => Color::Ansi256(242),
})),
)
}
fn write_color(
&self,
input: &str,
newline: bool,
color_spec: &mut ColorSpec,
) -> io::Result<()> {
let mut stdout = StandardStream::stdout(self.color_choice);
stdout.set_color(color_spec)?;
if newline {
writeln!(&mut stdout, "{input}")?;
} else {
write!(&mut stdout, "{input}")?;
}
stdout.reset()
}
}