10 unstable releases (3 breaking)

0.4.0 Dec 5, 2024
0.3.1 Jul 14, 2024
0.3.0 May 31, 2024
0.2.1 Feb 12, 2024
0.1.1 Aug 30, 2021

#64 in WebAssembly

Download history 4909/week @ 2024-10-26 3849/week @ 2024-11-02 4917/week @ 2024-11-09 4383/week @ 2024-11-16 4372/week @ 2024-11-23 4730/week @ 2024-11-30 4277/week @ 2024-12-07 4244/week @ 2024-12-14 2261/week @ 2024-12-21 1825/week @ 2024-12-28 4380/week @ 2025-01-04 3792/week @ 2025-01-11 4456/week @ 2025-01-18 4430/week @ 2025-01-25 4636/week @ 2025-02-01 4912/week @ 2025-02-08

19,076 downloads per month
Used in 12 crates (5 directly)

MIT license

32KB
710 lines

sprintf-rs

a clone of C sprintf in Rust

This crate was created out of a desire to provide C printf-style formatting in a WASM program, where there is no libc.

Note: You're probably better off using standard Rust string formatting instead of this crate unless you specificaly need printf compatibility.

This crate implements a dynamically type-checked function vsprintf and macro sprintf!.

Usage example:

use sprintf::sprintf;
let s = sprintf!("%d + %d = %d\n", 3, 9, 3+9).unwrap();
assert_eq!(s, "3 + 9 = 12\n");

libc is a dev dependency as it is used in the tests to compare results. std is used for some maths functions.


lib.rs:

Libc s(n)printf clone written in Rust, so you can use printf-style formatting without a libc (e.g. in WebAssembly).

Note: You're probably better off using standard Rust string formatting instead of thie crate unless you specificaly need printf compatibility.

It follows the standard C semantics, except:

  • Locale-aware UNIX extensions (' and GNU’s I) are not supported.
  • %a/%A (hexadecimal floating point) are currently not implemented.
  • Length modifiers (h, l, etc.) are checked, but ignored. The passed type is used instead.

Usage example:

 use sprintf::sprintf;
 let s = sprintf!("%d + %d = %d\n", 3, 9, 3+9).unwrap();
 assert_eq!(s, "3 + 9 = 12\n");

The types of the arguments are checked at runtime.

Dependencies

~225–680KB
~16K SLoC