mirror of
https://github.com/starship/starship.git
synced 2025-01-23 06:39:47 +01:00
fix: consider text-only meta variables in conditionals set
This commit is contained in:
parent
506a310a9e
commit
8343141ece
@ -364,7 +364,7 @@ impl<'a> StringFormatter<'a> {
|
||||
VariableValue::Meta(meta_elements) => {
|
||||
let meta_variables =
|
||||
clone_without_meta(variables);
|
||||
should_show_elements(
|
||||
should_show_meta_var(
|
||||
meta_elements,
|
||||
&meta_variables,
|
||||
)
|
||||
@ -383,6 +383,45 @@ impl<'a> StringFormatter<'a> {
|
||||
})
|
||||
}
|
||||
|
||||
// Check if a single format element should be shown.
|
||||
fn should_show_format_element<'a>(
|
||||
format_element: &FormatElement,
|
||||
variables: &'a VariableMapType<'a>,
|
||||
) -> bool {
|
||||
match format_element {
|
||||
// Should not usually happen, but if it does, check if the variable
|
||||
// is set using `should_show_elements`.
|
||||
FormatElement::Variable(_) => {
|
||||
should_show_elements(&[format_element.clone()], variables)
|
||||
}
|
||||
FormatElement::Conditional(format) => {
|
||||
should_show_elements(format, variables)
|
||||
}
|
||||
FormatElement::TextGroup(textgroup) => textgroup
|
||||
.format
|
||||
.iter()
|
||||
.any(|f| should_show_format_element(f, variables)),
|
||||
FormatElement::Text(t) => !t.is_empty(),
|
||||
}
|
||||
}
|
||||
|
||||
// If metavariables contain a variable they are treated set if one of them
|
||||
// is not empty.
|
||||
// If metavariables contain only text, they are also treated as set if the
|
||||
// string is not empty.
|
||||
fn should_show_meta_var<'a>(
|
||||
format_elements: &[FormatElement],
|
||||
variables: &'a VariableMapType<'a>,
|
||||
) -> bool {
|
||||
if !format_elements.get_variables().is_empty() {
|
||||
return should_show_elements(format_elements, variables);
|
||||
}
|
||||
|
||||
format_elements
|
||||
.iter()
|
||||
.any(|f| should_show_format_element(f, variables))
|
||||
}
|
||||
|
||||
let should_show: bool = should_show_elements(&format, variables);
|
||||
|
||||
if should_show {
|
||||
@ -756,6 +795,42 @@ mod tests {
|
||||
match_next!(result_iter, " ", None);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_conditional_meta_variable_empty_string() {
|
||||
const FORMAT_STR: &str = r"($colored $uncolored)";
|
||||
|
||||
let formatter = StringFormatter::new(FORMAT_STR)
|
||||
.unwrap()
|
||||
.map_meta(|var, _| match var {
|
||||
"colored" => Some("[](green)"),
|
||||
"uncolored" => Some(""),
|
||||
_ => None,
|
||||
});
|
||||
let result = formatter.parse(None, None).unwrap();
|
||||
|
||||
let mut result_iter = result.iter();
|
||||
assert!(result_iter.next().is_none());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_conditional_meta_variable_string() {
|
||||
const FORMAT_STR: &str = r"($colored $uncolored)";
|
||||
|
||||
let formatter = StringFormatter::new(FORMAT_STR)
|
||||
.unwrap()
|
||||
.map_meta(|var, _| match var {
|
||||
"colored" => Some("[green](green)"),
|
||||
"uncolored" => Some("text"),
|
||||
_ => None,
|
||||
});
|
||||
let result = formatter.parse(None, None).unwrap();
|
||||
let mut result_iter = result.iter();
|
||||
match_next!(result_iter, "green", Some(Color::Green.normal()));
|
||||
match_next!(result_iter, " ", None);
|
||||
match_next!(result_iter, "text", None);
|
||||
assert!(result_iter.next().is_none());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_variable_holder() {
|
||||
const FORMAT_STR: &str = "($a [($b) $c](none $s)) $d [t]($t)";
|
||||
|
@ -414,7 +414,7 @@ mod tests {
|
||||
.shell(Shell::Fish)
|
||||
.config(toml::toml! {
|
||||
[shell]
|
||||
bash_indicator = "B"
|
||||
fish_indicator = ""
|
||||
format = "($indicator )"
|
||||
disabled = false
|
||||
})
|
||||
|
Loading…
Reference in New Issue
Block a user