Crate r_i18n[][src]

r_i18n

An i18n implementation in Rust. Build Status

API documentation https://crates.io/crates/r_i18n Table of Contents generated with DocToc

Installation

To install the library, you have to put this line into your Cargo.toml file.

[dependencies]
r_i18n = "version number"

Usage

Configuration

First, create the configuration with the directory that contains your translations files and your languages.

extern crate r_i18n;
use r_i18n::I18nConfig;
fn main() {
    let config =  I18nConfig{locales: &["en", "fr", "es"], directory: "translations"};
}

Then, load the configuration:

extern crate r_i18n;
use r_i18n::I18n;
fn main() {
    let config: I18nConfig =  I18nConfig{locales: &["en", "fr", "es"], directory: "translations"};
    let r_i18n: I18n = I18n::configure(&config);
}

With this example, you will need to have a en.json, fr.json and es.json inside the /translations directory. Each file should looks like that:

{
    "keyword": "value"
}

Example

I have a en.json file that looks like that:

{
    "introduction": "Hello, my name is WebD"
}

Then, in my main.rs

extern crate r_i18n;
use r_i18n::I18n;
use r_i18n::I18nConfig;
fn main() {
    let config: I18nConfig =  I18nConfig{locales: &["en", "fr", "es"], directory: "translations"};
    let r_i18n: I18n = I18n::configure(&config);
    // by default, the current language will be the first element of the locales array. You can do like that if you want to set the language:
    // r_i18n.set_current_lang("fr");
    r_i18n.t("introduction"); // output should be "Hello, my name is WebD"
}

Now, I have a fr.json file that looks like that:

{
    "introduction": "Bonjour, mon nom est WebD"
}

If I set the current language to french:

extern crate r_i18n;
use r_i18n::I18n;
fn main() {
    let config: I18nConfig =  I18nConfig{locales: &["en", "fr", "es"], directory: "translations"};
    let r_i18n: I18n = I18n::configure(&config);
    r_i18n.set_current_lang("fr");
    r_i18n.t("introduction"); // output should be "Bonjour, mon nom est WebD
}

Contribution guide

  1. Fork and Clone the repository
  2. Create your own branch
  3. Start Coding!
  4. Make a pull request when you're done :)

Re-exports

pub use i18n::I18n;
pub use i18n::I18nConfig;

Modules

i18n