30 releases

Uses new Rust 2024

0.3.5 Jan 8, 2026
0.3.4 Oct 23, 2025
0.3.2 Oct 23, 2024
0.2.2 May 14, 2024
0.1.7 Oct 13, 2018

#46 in Rust patterns

Download history 717836/week @ 2025-10-20 753252/week @ 2025-10-27 730128/week @ 2025-11-03 687989/week @ 2025-11-10 785112/week @ 2025-11-17 703821/week @ 2025-11-24 803351/week @ 2025-12-01 803401/week @ 2025-12-08 783604/week @ 2025-12-15 539168/week @ 2025-12-22 529439/week @ 2025-12-29 789102/week @ 2026-01-05 886563/week @ 2026-01-12 915349/week @ 2026-01-19 1003504/week @ 2026-01-26 1186495/week @ 2026-02-02

4,066,681 downloads per month
Used in 4,864 crates (377 directly)

MIT/Apache

45KB
947 lines

smol_str

CI Crates.io API reference

A SmolStr is a string type that has the following properties:

  • size_of::<SmolStr>() == 24 (therefore == size_of::<String>() on 64 bit platforms)
  • Clone is O(1)
  • Strings are stack-allocated if they are:
    • Up to 23 bytes long
    • Longer than 23 bytes, but substrings of WS (see src/lib.rs). Such strings consist solely of consecutive newlines, followed by consecutive spaces
  • If a string does not satisfy the aforementioned conditions, it is heap-allocated
  • Additionally, a SmolStr can be explicitly created from a &'static str without allocation

Unlike String, however, SmolStr is immutable. The primary use case for SmolStr is a good enough default storage for tokens of typical programming languages. Strings consisting of a series of newlines, followed by a series of whitespace are a typical pattern in computer programs because of indentation. Note that a specialized interner might be a better solution for some use cases.

Benchmarks

Run criterion benches with

cargo bench --bench \* -- --quick

MSRV Policy

Minimal Supported Rust Version: latest stable.

Bumping MSRV is not considered a semver-breaking change.

Dependencies

~185KB