From 006724a184d3f7bbef2ce25f33b21058ac40770b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 10 Nov 2015 17:21:36 +0100 Subject: [PATCH] Refactor get_tags to return no Option --- src/module/bm/mod.rs | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/src/module/bm/mod.rs b/src/module/bm/mod.rs index 56be105f..2bcafccd 100644 --- a/src/module/bm/mod.rs +++ b/src/module/bm/mod.rs @@ -61,7 +61,7 @@ impl Module for BMModule { fn add<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> ModuleResult { let url = sub.value_of("url").unwrap(); let tags = get_tags(rt, sub); - info!("Adding url '{}' with tags '{:?}'", url, tags.unwrap_or(vec!())); + info!("Adding url '{}' with tags '{:?}'", url, tags); Ok(()) } @@ -74,10 +74,10 @@ fn list<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> ModuleResult { Some(reg) => { info!("Listing urls with matcher '{}' and with tags {:?}", reg.as_str(), - tags.unwrap_or(vec!())); + tags); } None => { - info!("Listing urls with tags {:?}", tags.unwrap_or(vec!())); + info!("Listing urls with tags {:?}", tags); } } @@ -97,11 +97,10 @@ fn remove<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> ModuleResult { match matcher { Some(reg) => { info!("Removing urls with matcher '{}' and with tags {:?}", - reg.as_str(), - tags.unwrap_or(vec!())); + reg.as_str(), tags); } None => { - info!("Listing urls with tags {:?}", tags.unwrap_or(vec!())); + info!("Listing urls with tags {:?}", tags); } } } @@ -110,23 +109,21 @@ fn remove<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> ModuleResult { Ok(()) } -fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Option> { +fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Vec { debug!("Fetching tags from commandline"); sub.value_of("tags").and_then(|tags| Some(tags.split(",") - .collect::>() - .iter() + .into_iter() + .map(|s| s.to_string()) .filter(|e| if e.contains(" ") { warn!("Tag contains spaces: '{}'", e); true } else { false - }) - .map(|s| s.to_string()) - .collect() + }).collect() ) - ) + ).or(Some(vec![])).unwrap() }