From 41de1e639229f9c65a52145d9c699c073345e061 Mon Sep 17 00:00:00 2001 From: 0xadk <0xadk@users.noreply.github.com> Date: Sat, 3 Aug 2024 01:50:31 -0700 Subject: [PATCH] refactor(color-eyre): improve `add_frame_filter` example and code readability --- color-eyre/examples/custom_filter.rs | 16 ++++++---------- color-eyre/src/config.rs | 28 ++++++++++------------------ 2 files changed, 16 insertions(+), 28 deletions(-) diff --git a/color-eyre/examples/custom_filter.rs b/color-eyre/examples/custom_filter.rs index 5776d38..5da8c82 100644 --- a/color-eyre/examples/custom_filter.rs +++ b/color-eyre/examples/custom_filter.rs @@ -9,18 +9,14 @@ fn main() -> Result<(), Report> { color_eyre::config::HookBuilder::default() .add_frame_filter(Box::new(|frames| { - let filters = &["custom_filter::main"]; + let filters = ["custom_filter::main"]; frames.retain(|frame| { - !filters.iter().any(|f| { - let name = if let Some(name) = frame.name.as_ref() { - name.as_str() - } else { - return true; - }; - - name.starts_with(f) - }) + let Some(name) = frame.name.as_deref() else { + return true; + }; + + !filters.iter().any(|f| name.starts_with(f)) }); })) .install() diff --git a/color-eyre/src/config.rs b/color-eyre/src/config.rs index f8f19b4..9b1148e 100644 --- a/color-eyre/src/config.rs +++ b/color-eyre/src/config.rs @@ -641,20 +641,16 @@ impl HookBuilder { /// ```rust /// color_eyre::config::HookBuilder::default() /// .add_frame_filter(Box::new(|frames| { - /// let filters = &[ + /// let filters = [ /// "uninteresting_function", /// ]; /// /// frames.retain(|frame| { - /// !filters.iter().any(|f| { - /// let name = if let Some(name) = frame.name.as_ref() { - /// name.as_str() - /// } else { - /// return true; - /// }; + /// let Some(name) = frame.name.as_deref() else { + /// return true; + /// }; /// - /// name.starts_with(f) - /// }) + /// !filters.iter().any(|f| name.starts_with(f)) /// }); /// })) /// .install() @@ -768,22 +764,18 @@ fn default_frame_filter(frames: &mut Vec<&Frame>) { } fn eyre_frame_filters(frames: &mut Vec<&Frame>) { - let filters = &[ + let filters = [ "::default", "eyre::", "color_eyre::", ]; frames.retain(|frame| { - !filters.iter().any(|f| { - let name = if let Some(name) = frame.name.as_ref() { - name.as_str() - } else { - return true; - }; + let Some(name) = frame.name.as_deref() else { + return true; + }; - name.starts_with(f) - }) + !filters.iter().any(|filter| name.starts_with(filter)) }); }