From c945a92fc97f45a55ec80d7ade88dd6427cdd60a Mon Sep 17 00:00:00 2001 From: Penelope Yong Date: Sun, 18 Aug 2024 13:55:02 +0100 Subject: [PATCH] Fix bug with same-day Proms concerts --- rust/src/proms.rs | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/rust/src/proms.rs b/rust/src/proms.rs index 00cbd30..4ff9c56 100644 --- a/rust/src/proms.rs +++ b/rust/src/proms.rs @@ -141,18 +141,17 @@ fn parse_single_concert(elem: ElementRef<'_>) -> PromsConcertMetadata { let price_text = elem .select(&price_selector) .next() - .unwrap_or_else(|| panic!("Couldn't find price for concert '{}'", title)) - .text() - .next() - .unwrap() - .trim(); + .map(|elem| elem.text().next().unwrap().trim()); // Regexes are hacky, but it works fine for now ... otherwise the website text is very // inconsistent and hard to parse. let price_re = Regex::new(r"£(\d+)").unwrap(); - let prices: Vec = price_re - .captures_iter(price_text) - .map(|cap| cap.get(1).unwrap().as_str().parse().unwrap()) - .collect(); + let prices: Vec = match price_text { + None => vec![], + Some(t) => price_re + .captures_iter(t) + .map(|cap| cap.get(1).unwrap().as_str().parse().unwrap()) + .collect(), + }; let (min_price, max_price) = match prices[..] { [] => (None, None), [price] => (Some(price * 100), Some(price * 100)),