#fmt #display #formatting #performance

no-std fast_fmt

This crate provides faster, more flexible and more correct alternative to core::fmt

2 releases

Uses old Rust 2015

0.1.3 Jul 2, 2017
0.1.2 Jun 3, 2017
0.1.1 May 30, 2017
0.1.0 May 29, 2017

#2655 in Rust patterns

Download history 2/week @ 2024-07-21 46/week @ 2024-07-28 6/week @ 2024-08-04 4/week @ 2024-08-11 1/week @ 2024-08-18 17/week @ 2024-09-01 12/week @ 2024-09-08 15/week @ 2024-09-22 4/week @ 2024-09-29 50/week @ 2024-10-06 5/week @ 2024-10-13 18/week @ 2024-10-20 13/week @ 2024-10-27 26/week @ 2024-11-03

64 downloads per month
Used in 4 crates

MITNFA license

23KB
460 lines

Fast fmt

Faster, more flexible and more correct alternative to core::fmt (AKA std::fmt)

Warning

This is WIP. Some APIs may change, some may lack documentation, others may be broken. Information in this README (especially benchmarks) may be misleading. Contributions are highly appreciated!

I don't promise to work on this much for a while!

Why is this faster?

  • Lack of trait objects allows compiler to optimize better.
  • Use of size_hint allows writers to e.g. pre-allocate large enough buffer.
  • Use of never type for errors comming from Write allows to optimize-out error checks.

Why more flexible?

Instead of multiple traits like Display, Debug, ... this crate defines single Fmt<S> which allows you to implement multiple different strategies, even your own. One possible use case is to implement Fmt<Localizer> to enable localization of your application.

Why more correct?

Instead of returning Err(()) on failed writes it returns apropriate types. It can even be Void to represent writers that can never fail (e.g. std::string::String).

How fast is it in practice?

The crate provides a very simple benchmark:

test bench::bench_core_fmt ... bench:         122 ns/iter (+/- 24)
test bench::bench_fast_fmt ... bench:          26 ns/iter (+/- 1)

It's consistently more than four times faster!

What to improve?

Roughly sorted by priority.

  • Documentation
  • Macros - ideally provide the same experience as core does.
  • More strategies
  • More impls (especially Fmt for primitives)
  • Bridge with core::fmt
  • Bridge with T: Iterator<char> + Clone?
  • Integrate with genio and provide encoders for different encodings.
  • Support for trait objects if someone want's them
  • Transformers (e.g. char escaping)
  • Asynchronous formatting maybe?
  • PR aginst core
  • Deprecate core::fmt

Last two are jokes.

Dependencies

~27KB