#cow-str #text #string

no-std cow-utils

Copy-on-write string utilities for Rust

4 releases

0.1.3 Sep 26, 2023
0.1.2 Feb 17, 2020
0.1.1 Feb 16, 2020
0.1.0 Feb 16, 2020

#64 in Text processing

Download history 48636/week @ 2025-09-23 46155/week @ 2025-09-30 53866/week @ 2025-10-07 54645/week @ 2025-10-14 65342/week @ 2025-10-21 65237/week @ 2025-10-28 65723/week @ 2025-11-04 63451/week @ 2025-11-11 67861/week @ 2025-11-18 70333/week @ 2025-11-25 77821/week @ 2025-12-02 74262/week @ 2025-12-09 75355/week @ 2025-12-16 51360/week @ 2025-12-23 60459/week @ 2025-12-30 77820/week @ 2026-01-06

279,724 downloads per month
Used in 329 crates (59 directly)

MIT license

16KB
115 lines

Copy-on-write string utils for Rust

Crate docs License

Some str methods perform destructive transformations and so they allocate, copy into and return a new String even when no modification is necessary.

This crate provides a helper trait CowUtils with drop-in variants of such methods, which behave in the same way, but avoid extra copies and allocations when no modification is necessary.

For now it's only implemented for &str and returns std::borrow::Cow<str>, but in the future might be extended to other types where even more efficient handling is possible (e.g. in-place modifications on mutable strings).

Performance

The primary motivation for this crate was ability to perform zero-alloc replacements when no match is found, so showing results only for .replace vs .cow_replace for now.

The actual results will vary depending on the inputs, but here is a taster based on "a".repeat(40) as an input and various modes (nothing matched, everything matched and replaced, everything matched from the start and deleted):

params .replace (ns) .cow_replace (ns) difference (%)
("a", "") 408.59 290.27 -29
("b", "c") 98.78 54.00 -45
("a", "b") 985.99 1,000.70 +1

Usage

First, you need to import CowUtils into the scope:

use cow_utils::CowUtils;

Then you can start invoking following .cow_-prefixed methods on strings instead of the regular ones:

Check out the docs for detailed examples.

No runtime deps