From 6851e6de57ed50f4c19d615cbe7a1b5979ecc944 Mon Sep 17 00:00:00 2001 From: Obei Sideg Date: Tue, 19 Sep 2023 21:13:26 +0300 Subject: [PATCH] Refactor `split_first` implementation for `Set` --- crates/formality-rust/src/grammar.rs | 2 +- crates/formality-types/src/collections.rs | 6 +----- 2 files changed, 2 insertions(+), 6 deletions(-) diff --git a/crates/formality-rust/src/grammar.rs b/crates/formality-rust/src/grammar.rs index 37cef86b..35a8403d 100644 --- a/crates/formality-rust/src/grammar.rs +++ b/crates/formality-rust/src/grammar.rs @@ -34,7 +34,7 @@ impl Program { _ => None, }) .collect(); - if traits.len() < 1 { + if traits.is_empty() { anyhow::bail!("no trait named `{trait_id:?}`") } else if traits.len() > 1 { anyhow::bail!("multiple traits named `{trait_id:?}`") diff --git a/crates/formality-types/src/collections.rs b/crates/formality-types/src/collections.rs index bf61b5a7..8f33a485 100644 --- a/crates/formality-types/src/collections.rs +++ b/crates/formality-types/src/collections.rs @@ -69,11 +69,7 @@ pub trait SetExt: Sized { impl SetExt for Set { fn split_first(self) -> Option<(T, Set)> { let mut iter = self.into_iter(); - if let Some(e) = iter.next() { - Some((e, iter.collect())) - } else { - None - } + iter.next().map(|e| (e, iter.collect())) } fn union_with(mut self, other: Self) -> Self {