Use a more streamlined version of style-component collection

This commit is contained in:
sharkdp 2018-09-12 21:35:23 +02:00
parent 7897260bf0
commit dccf8d8221
3 changed files with 16 additions and 17 deletions

View File

@ -12,7 +12,7 @@ use console::Term;
#[cfg(windows)] #[cfg(windows)]
use ansi_term; use ansi_term;
use assets::{BAT_STYLE_DEFAULT, BAT_THEME_DEFAULT}; use assets::BAT_THEME_DEFAULT;
use errors::*; use errors::*;
use line_range::LineRange; use line_range::LineRange;
use style::{OutputComponent, OutputComponents, OutputWrap}; use style::{OutputComponent, OutputComponents, OutputWrap};
@ -430,26 +430,25 @@ impl App {
[OutputComponent::Numbers].iter().cloned().collect() [OutputComponent::Numbers].iter().cloned().collect()
} else if matches.is_present("plain") { } else if matches.is_present("plain") {
[OutputComponent::Plain].iter().cloned().collect() [OutputComponent::Plain].iter().cloned().collect()
} else if matches.is_present("style") { } else {
values_t!(matches.values_of("style"), OutputComponent)? let env_style_components: Option<Vec<OutputComponent>> =
transpose(env::var("BAT_STYLE").ok().map(|style_str| {
style_str
.split(",")
.map(|x| OutputComponent::from_str(&x))
.collect::<Result<Vec<OutputComponent>>>()
}))?;
values_t!(matches.values_of("style"), OutputComponent)
.ok()
.or(env_style_components)
.unwrap_or(vec![OutputComponent::Full])
.into_iter() .into_iter()
.map(|style| style.components(self.interactive_output)) .map(|style| style.components(self.interactive_output))
.fold(HashSet::new(), |mut acc, components| { .fold(HashSet::new(), |mut acc, components| {
acc.extend(components.iter().cloned()); acc.extend(components.iter().cloned());
acc acc
}) })
} else {
let style_str = env::var("BAT_STYLE").unwrap_or(String::from(BAT_STYLE_DEFAULT));
style_str
.split(",")
.map(|x| OutputComponent::from_str(&x))
.map(|s| match s {
Ok(style) => style.components(self.interactive_output),
Err(_) => &[],
}).fold(HashSet::new(), |mut acc, components| {
acc.extend(components.iter().cloned());
acc
})
}, },
)) ))
} }

View File

@ -18,7 +18,6 @@ lazy_static! {
ProjectDirs::from("", "", crate_name!()).expect("Could not get home directory"); ProjectDirs::from("", "", crate_name!()).expect("Could not get home directory");
} }
pub const BAT_STYLE_DEFAULT: &str = "auto";
pub const BAT_THEME_DEFAULT: &str = "Monokai Extended"; pub const BAT_THEME_DEFAULT: &str = "Monokai Extended";
pub struct HighlightingAssets { pub struct HighlightingAssets {

View File

@ -54,7 +54,8 @@ impl FromStr for OutputComponent {
"header" => Ok(OutputComponent::Header), "header" => Ok(OutputComponent::Header),
"numbers" => Ok(OutputComponent::Numbers), "numbers" => Ok(OutputComponent::Numbers),
"full" => Ok(OutputComponent::Full), "full" => Ok(OutputComponent::Full),
"plain" | _ => Ok(OutputComponent::Plain), "plain" => Ok(OutputComponent::Plain),
_ => Err(format!("Unknown style '{}'", s).into()),
} }
} }
} }