rocket_i18n 0.4.1

Rocket fairing for easy internationalization with gettext (also supports Actix web)
Documentation
# Rocket I18N [![Build Status]https://travis-ci.org/Plume-org/rocket_i18n.svg?branch=master]https://travis-ci.org/Plume-Org/rocket_i18n

A crate to help you internationalize your Rocket or Actix Web applications.

It just selects the correct locale for each request, and return the corresponding `gettext::Catalog`.

## Usage

First add it to your `Cargo.toml`:

```toml
[dependencies]
rocket_i18n = "0.4"
gettext-macros = "0.1" # Provides proc-macros to manage translations
```

Then, in your `main.rs`:

```rust,ignore
# use rocket;
use gettext_macros::{compile_i18n, include_i18n, init_i18n};

init_i18n!("my_web_app", en, eo, it, pl);

fn main() {
    rocket::ignite()
        // Make Rocket manage your translations.
        .manage(include_i18n!());
        // Register routes, etc
}

compile_i18n!();
```

Then in all your requests you'll be able to use the `i18n` macro to translate anything.
It takes a `gettext::Catalog` and a string to translate as argument.

```rust,ignore
use gettext_macros::i18n;
use rocket_i18n::I18n;

#[get("/")]
fn route(i18n: I18n) -> &str {
    i18n!(i18n.catalog, "Hello, world!")
}
```

For a detailed explanation about `i18n!`, see [its documentation](https://docs.rs/gettext-macros/0.5.1/gettext_macros/macro.i18n.html).

You can also use the `t` macro in your templates, as long as they have a field called `catalog` to
store your catalog. This is especially useful for Askama templates.

### Using with Actix Web

First, disable the default features so it doesn't pull in all of Rocket.

```toml
[dependencies.rocket_i18n]
version = "0.4"
default-features = false
features = ["actix-web"]
```

Then add it to your application.

```rust
use gettext_macros::*;
use rocket_i18n::{I18n, Internationalized, Translations};

fn route_handler(i18n: I18n) -> &str {
    i18n!(i18n.catalog, "Hello, world!")
}

#[derive(Clone)]
struct MyState {
    translations: Translations,
}

impl Internationalized for MyState {
    fn get(&self) -> Translations {
        self.translations.clone()
    }
}

fn main() {
    let state = MyState {
        translations: rocket_i18n::i18n("your-domain", vec![ "en", "fr", "de", "ja" ]);
    };

    App::with_state(state)
        .resource("", |r| r.with(route_handler))
        .finish();
}
```