Crates.io | fluent-bundle |
lib.rs | fluent-bundle |
version | 0.16.0 |
created_at | 2019-02-01 00:23:18.678142+00 |
updated_at | 2025-05-22 14:01:00.200325+00 |
description | A low-level implementation of a collection of localization messages for a single locale for Project Fluent, a localization system designed to unleash the entire expressive power of natural language translations. |
homepage | https://www.projectfluent.org |
repository | https://github.com/projectfluent/fluent-rs |
max_upload_size | |
id | 111901 |
size | 149,671 |
The fluent-rs
workspace is a collection of Rust crates implementing Project Fluent,
a localization system designed to unleash the entire expressive power of natural language translations.
This crate is a low-level implementation of a collection of localization messages for a single locale.
use fluent_bundle::{FluentBundle, FluentResource};
use unic_langid::langid;
fn main() {
let ftl_string = "hello-world = Hello, world!".to_owned();
let res = FluentResource::try_new(ftl_string)
.expect("Could not parse an FTL string.");
let langid_en = langid!("en");
let mut bundle = FluentBundle::new(vec![langid_en]);
bundle.add_resource(&res)
.expect("Failed to add FTL resources to the bundle.");
let msg = bundle.get_message("hello-world")
.expect("Failed to retrieve a message.");
let val = msg.value.expect("Message has no value.");
let mut errors = vec![];
let value = bundle.format_pattern(val, None, &mut errors);
assert_eq!(&value, "Hello, world!");
}
fluent-rs
is open-source, licensed under both the Apache 2.0 and MIT licenses. We
encourage everyone to take a look at our code and we'll listen to your
feedback.
We'd love to hear your thoughts on Project Fluent! Whether you're a localizer looking for a better way to express yourself in your language, or a developer trying to make your app localizable and multilingual, or a hacker looking for a project to contribute to, please do get in touch on the mailing list and the IRC channel.