From d8a79eafdc5250ee9939976fd649b45e15a085b3 Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Sat, 21 Dec 2024 11:06:11 -0800 Subject: [PATCH] Document formatting of bit-fields and fields of packed structs --- doc/api.md | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/doc/api.md b/doc/api.md index 86808fc1..03a1d77d 100644 --- a/doc/api.md +++ b/doc/api.md @@ -511,7 +511,7 @@ chrono-format-specifications). ::: ptr(const std::shared_ptr&) -### Formatting Variants +### Variants A `std::variant` is only formattable if every variant alternative is formattable, and requires the `__cpp_lib_variant` [library @@ -527,6 +527,23 @@ feature](https://en.cppreference.com/w/cpp/feature_test). fmt::print("{}", std::variant()); // Output: variant(monostate) +## Bit-Fields and Packed Structs + +To format a bit-field or a field of a struct with `__attribute__((packed))` +applied to it, you need to convert it to the underlying or compatible type via +a cast or a unary `+` ([godbolt](https://www.godbolt.org/z/3qKKs6T5Y)): + +```c++ +struct smol { + int bit : 1; +}; + +auto s = smol(); +fmt::print("{}", +s.bit); +``` + +This is a known limitation of "perfect" forwarding in C++. + ## Format String Compilation