#fluent #localization

intl-memoizer

A memoizer specifically tailored for storing lazy-initialized intl formatters for Project Fluent, a localization system designed to unleash the entire expressive power of natural language translations

7 unstable releases

0.5.3 May 22, 2025
0.5.2 May 5, 2024
0.5.1 Jan 23, 2021
0.5.0 May 6, 2020
0.2.0 Feb 13, 2020

#686 in Internationalization (i18n)

Download history 82289/week @ 2025-10-26 75563/week @ 2025-11-02 82547/week @ 2025-11-09 71051/week @ 2025-11-16 82225/week @ 2025-11-23 87292/week @ 2025-11-30 100906/week @ 2025-12-07 100231/week @ 2025-12-14 111410/week @ 2025-12-21 149666/week @ 2025-12-28 148258/week @ 2026-01-04 133070/week @ 2026-01-11 154614/week @ 2026-01-18 134847/week @ 2026-01-25 192978/week @ 2026-02-01 193489/week @ 2026-02-08

698,345 downloads per month
Used in 537 crates (36 directly)

Apache-2.0 OR MIT

23KB
178 lines

IntlMemoizer

crates.io docs.rs Build Coverage Status

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 memoizer specifically tailored for storing lazy-initialized intl formatters.

Usage

The assumption is that allocating a new formatter instance is costly, and such instance is read-only during its life time, with constructor being expensive, and format/select calls being cheap.

In result it pays off to use a singleton to manage memoization of all instances of intl APIs such as PluralRules, DateTimeFormat etc. between all FluentBundle instances.

The following is a high-level example of how this works, for running examples see the docs

/// Internationalization formatter should implement the Memoizable trait.
impl Memoizable for NumberFormat {
  ...
}

// The main memoizer has weak references to all of the per-language memoizers.
let mut memoizer = IntlMemoizer::default();

// The formatter memoziation happens per-locale.
let lang = "en-US".parse().expect("Failed to parse.");
let lang_memoizer: Rc<IntlLangMemoizer> = memoizer.get_for_lang(en_us);

// Run the formatter

let options: NumberFormatOptions {
    minimum_fraction_digits: 3,
    maximum_fraction_digits: 5,
};

// Format pi with the options. This will lazily construct the NumberFormat.
let pi = lang_memoizer
    .with_try_get::<NumberFormat, _, _>((options,), |nf| nf.format(3.141592653))
    .unwrap()

// The example formatter constructs a string with diagnostic information about
// the configuration.
assert_eq!(text, "3.14159");

// Running it again will use the previous formatter.
let two = lang_memoizer
    .with_try_get::<NumberFormat, _, _>((options,), |nf| nf.format(2.0))
    .unwrap()

assert_eq!(text, "2.000");

Get Involved

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.

Discuss

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.

Dependencies

~0.8–1.2MB
~26K SLoC