french-numbers

Build Status Current Version Documentation License: Apache-2.0/MIT

This crate transforms a number into its French representation.

Using this crate

In your Cargo.toml, put:

ini [dependencies] french-numbers = "1.1.1"

You can then use the french_number function from the french_numbers crate to format any integer into the beautiful French romance language:

``` rust use frenchnumbers::frenchnumber;

asserteq!(frenchnumber(&71), "soixante-et-onze"); asserteq!(frenchnumber(&1001), "mille-un"); asserteq!(frenchnumber(&-200001), "moins deux-cent-mille-un"); asserteq!(frenchnumber(&-200000001), "moins deux-cents-millions-un"); asserteq!(frenchnumber(&-204000001), "moins deux-cent-quatre-millions-un"); ```

You can also request the use of the feminine form, or prefer the previous way of writing numbers predating the 1990 orthographic reform:

```rust use french_numbers::*;

asserteq!(frenchnumberoptions(&37251061, &POSTREFORMMASCULINE), "trente-sept-millions-deux-cent-cinquante-et-un-mille-soixante-et-un"); asserteq!(frenchnumberoptions(&37251061, &POSTREFORMFEMININE), "trente-sept-millions-deux-cent-cinquante-et-un-mille-soixante-et-une"); asserteq!(frenchnumberoptions(&37251061, &PREREFORMFEMININE), "trente-sept millions deux cent cinquante et un mille soixante et une"); asserteq!(frenchnumberoptions(&37251061, &PREREFORMMASCULINE), "trente-sept millions deux cent cinquante et un mille soixante et un") ```

An example program can dump particular number, with different options:

``` bash % cargo run --example french-number -- --help Print number(s) in French

USAGE: french-number [FLAGS] [HIGH]

FLAGS: -f, --feminine use the feminine declination -h, --help Prints help information -r, --no-reform use the pre-1990 orthographic reform writing -p, --prefix prefix output with the numerical representation -V, --version Prints version information

ARGS: number (or low bound) to use optional high bound ```