diff --git a/README.md b/README.md index 56f6118..ebc5bc9 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ [![Documentation](https://img.shields.io/badge/docs.rs-nucleo--picker-66c2a5?labelColor=555555&logoColor=white&logo=)](https://docs.rs/nucleo-picker/) # nucleo-picker -A [Rust](https://www.rust-lang.org/) library which enables you to incorporate a highly performant and Unicode-aware fuzzy picker directly in your own terminal application. +A native [Rust](https://www.rust-lang.org/) library which enables you to incorporate a highly performant and Unicode-aware fuzzy picker directly in your own terminal application. This library provides a TUI for the [`nucleo`](https://docs.rs/nucleo/latest/nucleo/) crate with an interface similar to the [fzf](https://github.com/junegunn/fzf) command-line tool. @@ -35,7 +35,7 @@ Why use this library instead of a general-purpose fuzzy-finder such as `fzf` or - Customizable rendering of crate-local and foreign types with the `Render` trait. ## Example -Implement a heavily simplified `fzf` clone in 30 lines of code. +Implement a heavily simplified `fzf` clone in 25 lines of code. Try it out with: ``` cargo build --release --example fzf @@ -57,9 +57,8 @@ fn main() -> io::Result<()> { let injector = picker.injector(); spawn(move || { for line in io::stdin().lock().lines() { - match line { - Ok(s) => injector.push(s), - Err(_) => {} + if let Ok(s) = line { + injector.push(s); } } }); diff --git a/examples/fzf.rs b/examples/fzf.rs index 974f0bf..d7ac8bd 100644 --- a/examples/fzf.rs +++ b/examples/fzf.rs @@ -16,10 +16,9 @@ fn main() -> io::Result<()> { let injector = picker.injector(); spawn(move || { for line in io::stdin().lock().lines() { - match line { - Ok(s) => injector.push(s), - // silently drop io errors! - Err(_) => {} + // silently drop IO errors! + if let Ok(s) = line { + injector.push(s); } } });