prefer if let where possible, removes empty blocks and reduces nesting

This commit is contained in:
Adrian Malacoda 2017-05-17 21:23:00 -05:00
parent c69cc61114
commit 0b289b6956

View File

@ -12,7 +12,7 @@ use stc::Link;
use stc::searchers::{Searcher, AggregateSearcher};
use stc::searchers::yugioh::{YugiohCard, YugiohSearcher};
use stc::searchers::mtg::{MtgCard, MtgSearcher};
use stc::searchers::mediawiki::{WikiPage, MediawikiSearcher};
use stc::searchers::mediawiki::MediawikiSearcher;
use regex::Regex;
@ -30,68 +30,52 @@ impl AutolinkModule {
fn print_mtg_card (card: &MtgCard, message: &Message) {
message.reply(&format!("{}", card.image_url));
message.reply(&format!("**{}** (**{}**)", card.name, card.cost));
if let Some(ref cost) = card.cost {
message.reply(&format!("**{}** (**{}**)", card.name, cost));
} else {
message.reply(&format!("**{}**", card.name));
}
message.reply(&format!("**{}**", card.typeline));
message.reply(&format!("{}", card.rules));
match card.flavor {
Some(ref flavor) => message.reply(&format!("*{}*", flavor)),
None => {}
if let Some(ref flavor) = card.flavor {
message.reply(&format!("*{}*", flavor));
}
// 12 March 2017: Is there a better way to do this?
match card.power {
Some(ref power) => {
match card.toughness {
Some(ref toughness) => {
if let Some(ref power) = card.power {
if let Some(ref toughness) = card.toughness {
message.reply(&format!("{}/{}", power, toughness));
},
None => {}
}
}
None => {}
}
}
fn print_ygo_card (card: &YugiohCard, message: &Message) {
match card.family {
Some(ref family) => {
if let Some(ref family) = card.family {
message.reply(&format!("**{}** ({})", card.name, family));
},
None => {
} else {
message.reply(&format!("**{}**", card.name));
}
}
match card.level {
Some(ref level) => {
if let Some(ref level) = card.level {
message.reply(&format!("**Level**: {}", level));
}
None => {}
}
match card.subtype {
Some(ref subtype) => {
if let Some(ref subtype) = card.subtype {
message.reply(&format!("**{} - {}**", card.card_type, subtype));
}
None => {
} else {
message.reply(&format!("**{}**", card.card_type));
}
}
message.reply(&format!("{}", card.text));
match card.atk {
Some(ref atk) => {
match card.def {
Some(ref def) => {
if let Some(ref atk) = card.atk {
if let Some(ref def) = card.def {
message.reply(&format!("{}/{}", atk, def));
},
None => {}
}
}
None => {}
}
}
fn print_any_link (link: &Link, message: &Message) {
@ -112,8 +96,7 @@ impl EventLoop for AutolinkModule {
loop {
match receiver.recv() {
Ok(envelope) => {
match envelope.event {
Event::Message { ref message } => {
if let Event::Message { ref message } = envelope.event {
debug!("Received message from module {:?}... {:?}", envelope.from, message.content);
for cap in link_regex.captures_iter(&message.content) {
if let Some(item) = searchers.exact_search(&cap[1]) {
@ -126,8 +109,6 @@ impl EventLoop for AutolinkModule {
}
}
}
_ => ()
}
}
Err(error) => { error!("Error {:?}", error) }
}