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 5139/week @ 2024-10-22 4217/week @ 2024-10-29 4164/week @ 2024-11-05 5048/week @ 2024-11-12 4314/week @ 2024-11-19 4256/week @ 2024-11-26 4809/week @ 2024-12-03 4184/week @ 2024-12-10 4167/week @ 2024-12-17 1871/week @ 2024-12-24 2776/week @ 2024-12-31 3928/week @ 2025-01-07 3874/week @ 2025-01-14 4409/week @ 2025-01-21 4395/week @ 2025-01-28 3981/week @ 2025-02-04

17,246 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–670KB
~16K SLoC