#suggestions #did #mean #distance #collection #unknown #run-time

suggest

A minimal library to provide similar name suggestions like "Did you mean?"

3 unstable releases

0.5.1 Feb 14, 2024
0.5.0 Apr 26, 2023
0.4.0 May 9, 2022

#357 in Data structures

Download history 739/week @ 2024-08-02 779/week @ 2024-08-09 832/week @ 2024-08-16 904/week @ 2024-08-23 802/week @ 2024-08-30 700/week @ 2024-09-06 803/week @ 2024-09-13 944/week @ 2024-09-20 929/week @ 2024-09-27 833/week @ 2024-10-04 811/week @ 2024-10-11 831/week @ 2024-10-18 704/week @ 2024-10-25 1443/week @ 2024-11-01 1223/week @ 2024-11-08 1920/week @ 2024-11-15

5,405 downloads per month
Used in 3 crates

MIT license

11KB
134 lines

suggest crates.io version crates.io downloads

A minimal library to provide similar name suggestions like "Did you mean?" This library provides suggestion traits for all collection types in the standard library.

This library is intended to suggest a candidate from a list of unknown suggestions until runtime, in addition to the suggestion feature already available in clap.

Installation

Add the following to your Cargo.toml:

[dependencies]
suggest = "0.5"

Examples

Simple case

This example can be executed by the cargo run --example simple command.

use suggest::Suggest;

fn main() {
    let input = "instakk";

    let list_commands = vec!["update", "install"];
    if list_commands.contains(&input) {
        return;
    }

    if let Some(sugg) = list_commands.suggest(input) {
        println!("No command named `{}` found.", input);
        println!("Did you mean `{}`?", sugg);
    }
}
$ cargo run
No command named `instakk` found.
Did you mean `install`?

Specifying distance

use suggest::Suggest;

fn main() {
    let input = "paoc";

    let list_commands = vec!["poac", "poacpp"];
    if list_commands.contains(&input) {
        return;
    }

    if let Some(sugg) = list_commands.suggest_by(input, 2) {
        println!("No command named `{}` found.", input);
        println!("Did you mean `{}`?", sugg);
    }
}
$ cargo run
No command named `paoc` found.
Did you mean `poac`?

Supported types

Please let me know if anything is left out through issues or pull requests.

Sequences

  • LinkedList
  • VecDeque
  • Vec

Maps

  • HashMap
  • BTreeMap

To suggest keys, use suggest::SuggestKey trait.

Sets

  • BTreeSet
  • HashSet

Misc

  • BinaryHeap
  • [T; N]: primitive array
  • [T]: slices

Contribution

Contributions, including issues and pull requests, are very welcome.

Build

$ cargo build

Test

$ cargo build
$ cargo test

Publish

GitHub Releases

$ git tag v0.1.0
$ git push origin v0.1.0

crates.io

$ cargo publish

Dependencies

~13KB