From 4e6de02410196f32943f93a0678cee9b2f2c5727 Mon Sep 17 00:00:00 2001 From: Federico Terzi Date: Mon, 2 Mar 2020 23:51:31 +0100 Subject: [PATCH] Implement case propagation. Fix #152 --- src/matcher/mod.rs | 10 +++++ src/render/default.rs | 101 +++++++++++++++++++++++++++++++++++++++++- 2 files changed, 110 insertions(+), 1 deletion(-) diff --git a/src/matcher/mod.rs b/src/matcher/mod.rs index 0f2f191..3e9c294 100644 --- a/src/matcher/mod.rs +++ b/src/matcher/mod.rs @@ -459,4 +459,14 @@ mod tests { assert_eq!(_match._trigger_sequences[2][3], TriggerEntry::Char('T')); assert_eq!(_match._trigger_sequences[2][4], TriggerEntry::WordSeparator); } + + #[test] + fn test_match_empty_replace_doesnt_crash() { + let match_str = r###" + trigger: "hello" + replace: "" + "###; + + let _match : Match = serde_yaml::from_str(match_str).unwrap(); + } } \ No newline at end of file diff --git a/src/render/default.rs b/src/render/default.rs index f8f3802..adfed8e 100644 --- a/src/render/default.rs +++ b/src/render/default.rs @@ -158,7 +158,46 @@ impl super::Renderer for DefaultRenderer { // Render any argument that may be present let target_string = utils::render_args(&target_string, &args); - // TODO: add case affect expansion here + // Handle case propagation + let target_string = if m.propagate_case { + let trigger = &m.triggers[trigger_offset]; + let first_char = trigger.chars().nth(0); + let second_char = trigger.chars().nth(1); + let mode: i32 = if let Some(first_char) = first_char { + if first_char.is_uppercase() { + if let Some(second_char) = second_char { + if second_char.is_uppercase() { + 2 // Full CAPITALIZATION + }else{ + 1 // Only first letter capitalized: Capitalization + } + }else{ + 2 // Single char, defaults to full CAPITALIZATION + } + }else{ + 0 // Lowercase, no action + } + }else{ + 0 + }; + + match mode { + 1 => { + // Capitalize the first letter + let mut v: Vec = target_string.chars().collect(); + v[0] = v[0].to_uppercase().nth(0).unwrap(); + v.into_iter().collect() + }, + 2 => { // Full capitalization + target_string.to_uppercase() + }, + _ => { // Noop + target_string + } + } + }else{ + target_string + }; RenderResult::Text(target_string) }, @@ -560,4 +599,64 @@ mod tests { verify_render(rendered, "Hi Jon"); } + + #[test] + fn test_render_match_case_propagation_no_case() { + let config = get_config_for(r###" + matches: + - trigger: 'test' + replace: result + propagate_case: true + "###); + + let renderer = get_renderer(config.clone()); + + let m = config.matches[0].clone(); + + let trigger_offset = m.triggers.iter().position(|x| x== "test").unwrap(); + + let rendered = renderer.render_match(&m, trigger_offset, &config, vec![]); + + verify_render(rendered, "result"); + } + + #[test] + fn test_render_match_case_propagation_first_capital() { + let config = get_config_for(r###" + matches: + - trigger: 'test' + replace: result + propagate_case: true + "###); + + let renderer = get_renderer(config.clone()); + + let m = config.matches[0].clone(); + + let trigger_offset = m.triggers.iter().position(|x| x== "Test").unwrap(); + + let rendered = renderer.render_match(&m, trigger_offset, &config, vec![]); + + verify_render(rendered, "Result"); + } + + #[test] + fn test_render_match_case_propagation_all_capital() { + let config = get_config_for(r###" + matches: + - trigger: 'test' + replace: result + propagate_case: true + "###); + + let renderer = get_renderer(config.clone()); + + let m = config.matches[0].clone(); + + let trigger_offset = m.triggers.iter().position(|x| x== "TEST").unwrap(); + + let rendered = renderer.render_match(&m, trigger_offset, &config, vec![]); + + verify_render(rendered, "RESULT"); + } } \ No newline at end of file