fix(core): fix bug that skipped propagate_case check

This commit is contained in:
Federico Terzi 2021-05-11 21:14:53 +02:00
parent 46b9382fef
commit 2eef404d6c

View File

@ -202,10 +202,13 @@ impl<'a> Renderer<'a> for RendererAdapter<'a> {
.or_insert_with(|| generate_context(&match_set, &self.template_map, &self.global_vars_map)); .or_insert_with(|| generate_context(&match_set, &self.template_map, &self.global_vars_map));
let raw_match = self.match_provider.get(match_id); let raw_match = self.match_provider.get(match_id);
let propagate_case = raw_match.map(is_propagate_case).unwrap_or(false);
let preferred_uppercasing_style = raw_match.and_then(extract_uppercasing_style); let preferred_uppercasing_style = raw_match.and_then(extract_uppercasing_style);
let options = RenderOptions { let options = RenderOptions {
casing_style: if let Some(trigger) = trigger { casing_style: if !propagate_case {
CasingStyle::None
} else if let Some(trigger) = trigger {
calculate_casing_style(trigger, preferred_uppercasing_style) calculate_casing_style(trigger, preferred_uppercasing_style)
} else { } else {
CasingStyle::None CasingStyle::None
@ -254,6 +257,14 @@ fn extract_uppercasing_style(m: &Match) -> Option<UpperCasingStyle> {
} }
} }
fn is_propagate_case(m: &Match) -> bool {
if let MatchCause::Trigger(cause) = &m.cause {
cause.propagate_case
} else {
false
}
}
// TODO: test // TODO: test
fn calculate_casing_style( fn calculate_casing_style(
trigger: &str, trigger: &str,