#string-cache #atom #string

string_cache

A string interning library for Rust, developed as part of the Servo project

69 releases

0.8.9 Mar 28, 2025
0.8.7 Mar 7, 2023
0.8.4 Mar 27, 2022
0.8.2 Oct 12, 2021
0.1.10 Jul 30, 2015

#4 in Caching

Download history 237750/week @ 2024-12-20 214582/week @ 2024-12-27 372578/week @ 2025-01-03 470134/week @ 2025-01-10 419516/week @ 2025-01-17 447531/week @ 2025-01-24 539487/week @ 2025-01-31 583428/week @ 2025-02-07 540297/week @ 2025-02-14 599339/week @ 2025-02-21 587440/week @ 2025-02-28 617884/week @ 2025-03-07 657564/week @ 2025-03-14 613909/week @ 2025-03-21 648960/week @ 2025-03-28 655560/week @ 2025-04-04

2,697,496 downloads per month
Used in 2,700 crates (58 directly)

MIT/Apache

34KB
502 lines

string-cache

Build Status

Documentation

A string interning library for Rust, developed as part of the Servo project.

Simple usage

In Cargo.toml:

[dependencies]
string_cache = "0.8"

In lib.rs:

extern crate string_cache;
use string_cache::DefaultAtom as Atom;

With static atoms

In Cargo.toml:

[package]
build = "build.rs"

[dependencies]
string_cache = "0.8"

[build-dependencies]
string_cache_codegen = "0.5"

In build.rs:

extern crate string_cache_codegen;

use std::env;
use std::path::Path;

fn main() {
    string_cache_codegen::AtomType::new("foo::FooAtom", "foo_atom!")
        .atoms(&["foo", "bar"])
        .write_to_file(&Path::new(&env::var("OUT_DIR").unwrap()).join("foo_atom.rs"))
        .unwrap()
}

In lib.rs:

extern crate string_cache;

mod foo {
    include!(concat!(env!("OUT_DIR"), "/foo_atom.rs"));
}

The generated code will define a FooAtom type and a foo_atom! macro. The macro can be used in expression or patterns, with strings listed in build.rs. For example:

fn compute_something(input: &foo::FooAtom) -> u32 {
    match *input {
        foo_atom!("foo") => 1,
        foo_atom!("bar") => 2,
        _ => 3,
    }
}

Dependencies

~0.4–5MB
~16K SLoC