Expand description

thesaurus-rs

Crates.io Crates.io API

The offline thesaurus library for Rust that can use both wordnet and moby thesauruses.

Add to Cargo.toml for wordnet:

thesaurus = "0.5"

Add to Cargo.toml for just moby (wordnet and static are on by default):

thesaurus = { version = "0.5", features = ["moby","static"], default_features = false }

Crate Feature “static

static is a feature that is turned on by default that the thesaurus dictionary to be stored in memory during runtime. This allows calls to dict and synonyms to be 2.5-3x faster after initialization with the added downside of increased memory usage. To turn off static, use the default_features = false option.

Backend Comparison

NameSimple Example Binary SizeSimple Example Binary Size (Stripped)Available WordsAverage Number of SynonymsCompressed Dictionary SizeLicense
Moby15M11M3015983.28711MUS Public Domain
Wordnet6.9M3.4M1257013.3942.9MWordnet License

Basic Example

use std::{env, process};

fn main() {
    let args = env::args().collect::<Vec<String>>();

    let word: String = match args.get(1) {
        Some(word) => word.to_string(),
        None => {
            eprintln!("Must include a word as an argument");
            process::exit(1);
        }
    };

    let synonyms = thesaurus::synonyms(&word);
    let num_words = thesaurus::dict().len();

    cfg_if::cfg_if! {
        if #[cfg(all(feature = "moby", feature = "wordnet"))] {
            print!("both wordnet and moby have ");
        } else if #[cfg(feature = "moby")] {
            print!("moby has ");
        } else if #[cfg(feature = "wordnet")] {
            print!("wordnet has ");
        }
    }

    println!("{num_words} words indexed, and {} synonyms for \"{word}\"...", synonyms.len());
    println!("synonyms...");
    for x in &synonyms {
        println!("   {x}");
    }
}

Wordnet Output

 $ cargo r -rq --example simple -- good
wordnet has 125701 words indexed, and 107 synonyms for "good"...
synonyms...
   acceptable
   adept
   advantageous
   ample
   angelic
   angelical
   bang-up
   beatific
   beneficial
   beneficial
   best
...

Moby Output

 $ cargo r -rq --example simple --no-default-features --features=moby -- good
moby has 30195 words indexed, and 666 synonyms for "good"...
synonyms...
   able to pay
   absolutely
   acceptable
   accomplished
   according to hoyle
   ace
   actual
   adept
   adequate
   admirable
   admissible
   adroit
   advantage
   advantageous
...

Both Output

 $ cargo r -rq --example simple --features=moby,wordnet -- good
both wordnet and moby have 132592 words indexed, and 773 synonyms for "good"...
synonyms...
   able to pay
   absolutely
   acceptable
   acceptable
   accomplished
   according to hoyle
   ace
   actual
   adept
   adept
   adequate
   admirable
   admissible
   adroit
...

Functions

Return the internal dictionary.

initstatic

Initialize a global dictionary so initialization isn’t done on the first call to synonyms or dict.

Return synonyms for a word.