#nlp #english #text #grammar

in_definite

Get the indefinite article ('a' or 'an') to match the given word. For example: an umbrella, a user.

18 releases (1 stable)

1.0.0 Sep 4, 2023
0.2.5 Mar 12, 2022
0.2.4 Nov 14, 2020
0.2.3 Mar 18, 2020
0.1.10 Sep 21, 2019

#322 in Text processing

Download history 1288/week @ 2024-09-15 870/week @ 2024-09-22 580/week @ 2024-09-29 766/week @ 2024-10-06 689/week @ 2024-10-13 1961/week @ 2024-10-20 1147/week @ 2024-10-27 870/week @ 2024-11-03 721/week @ 2024-11-10 418/week @ 2024-11-17 312/week @ 2024-11-24 330/week @ 2024-12-01 472/week @ 2024-12-08 517/week @ 2024-12-15 43/week @ 2024-12-22 274/week @ 2024-12-29

1,332 downloads per month
Used in 19 crates (3 directly)

MIT license

27KB
596 lines

in_definite

Rust port of indefinite on npm, for deciding which indefinite article to use ('a' or 'an').

Get the indefinite article ('a' or 'an') to match the given word. For example: an umbrella, a user.

Rust

Examples

use in_definite;

let result = in_definite::get_a_or_an("alien");
assert_eq!("an", result);
// Irregular word
let result = in_definite::get_a_or_an("unicorn");
assert_eq!("a", result);
// Title Case
let result = in_definite::get_a_or_an("Ugly");
assert_eq!("An", result);
let result = in_definite::is_an("alien");
assert_eq!(in_definite::Is::An, result);
let result = in_definite::is_an("unicorn");
assert_eq!(in_definite::Is::A, result);

Deviations from the original indefinite

Upper/lower/mixed case handling:

  • a word like THIS will be always considered to be an acronym.
  • normally the result is lower case ('a' or 'an')
  • title case is handled as: 'Ugly' -> 'An'
  • mixed case is handled as: 'uGly' -> 'an'

Adverbs:

  • Handles adverbs with '-ly' in a generic manner. Example: "a ubiquitously"

A big thanks to the original authors of indefinite!

Published @ crates.io

https://crates.io/crates/in_definite

licence = MIT

This project is licensed under the MIT License - see the LICENSE file for details

No runtime deps