7 releases

0.2.1 Feb 12, 2024
0.2.0 Feb 12, 2024
0.1.4 Sep 10, 2023
0.1.3 Sep 23, 2022
0.1.1 Aug 30, 2021

#89 in WebAssembly

Download history 1419/week @ 2024-01-01 2156/week @ 2024-01-08 1928/week @ 2024-01-15 1855/week @ 2024-01-22 3659/week @ 2024-01-29 4622/week @ 2024-02-05 3905/week @ 2024-02-12 3286/week @ 2024-02-19 4357/week @ 2024-02-26 3116/week @ 2024-03-04 2953/week @ 2024-03-11 3642/week @ 2024-03-18 3240/week @ 2024-03-25 4663/week @ 2024-04-01 4785/week @ 2024-04-08 4991/week @ 2024-04-15

17,801 downloads per month
Used in 7 crates (3 directly)

MIT license

30KB
640 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 thie 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

~325–780KB
~19K SLoC