Difference between revisions of "cpp/utility/format/format to n"
(no, `result.size` is not clamped) |
m (→Example: added more info.) |
||
Line 66: | Line 66: | ||
===Example=== | ===Example=== | ||
− | {{example| | + | {{example |
+ | |At Godbolt's Compiler Explorer: [https://godbolt.org/z/feTecEb3s clang (trunk) + libc++], [https://godbolt.org/z/963fPbj37 gcc (trunk) + libstdc++]. | ||
|code= | |code= | ||
#include <format> | #include <format> | ||
Line 76: | Line 77: | ||
char buffer[64]; | char buffer[64]; | ||
− | + | for (std::size_t max_chars_to_write : {std::size(buffer) - 1, 23uz}) | |
− | + | { | |
− | + | const auto result = | |
− | + | std::format_to_n( | |
− | + | buffer, max_chars_to_write, | |
− | + | "Hubble's H{2} {3} {0}{4}{1} km/sec/Mpc.", // 24 bytes w/o formatters | |
− | + | 71, // {0}, occupies 2 bytes | |
− | + | 8, // {1}, occupies 1 byte | |
− | + | "\u2080", // {2}, occupies 3 bytes, '₀' (SUBSCRIPT ZERO) | |
− | + | "\u2245", // {3}, occupies 3 bytes, '≅' (APPROXIMATELY EQUAL TO) | |
+ | "\u00B1" // {4}, occupies 2 bytes, '±' (PLUS-MINUS SIGN) | ||
+ | ); // 24 + 2 + 1 + 3 + 3 + 2 == 35, no trailing '\0' | ||
− | + | *result.out = '\0'; // adds terminator to buffer | |
− | + | const std::string_view str{buffer, result.out}; // uses C++20 constructor | |
− | + | ||
− | + | std::cout << "Buffer until '\\0': \"" << str << "\"\n" | |
+ | << "Max chars to write: " << max_chars_to_write << '\n' | ||
+ | << "result.out offset: " << result.out - buffer << '\n' | ||
+ | << "Untruncated output size: " << result.size << "\n\n"; | ||
+ | } | ||
} | } | ||
|output= | |output= | ||
− | Buffer: "Hubble's H₀ ≅ 71±8 km/sec/Mpc." | + | Buffer until '\0': "Hubble's H₀ ≅ 71±8 km/sec/Mpc." |
− | + | Max chars to write: 63 | |
− | Untruncated output size | + | result.out offset: 35 |
+ | Untruncated output size: 35 | ||
+ | |||
+ | Buffer until '\0': "Hubble's H₀ ≅ 71±8" | ||
+ | Max chars to write: 23 | ||
+ | result.out offset: 23 | ||
+ | Untruncated output size: 35 | ||
}} | }} | ||
Revision as of 10:21, 25 September 2023
Defined in header <format>
|
||
template< class OutputIt, class... Args > std::format_to_n_result<OutputIt> |
(1) | (since C++20) |
template< class OutputIt, class... Args > std::format_to_n_result<OutputIt> |
(2) | (since C++20) |
template< class OutputIt, class... Args > std::format_to_n_result<OutputIt> |
(3) | (since C++20) |
template< class OutputIt, class... Args > std::format_to_n_result<OutputIt> |
(4) | (since C++20) |
Helper types |
||
template< class OutputIt > struct format_to_n_result { |
(5) | (since C++20) |
Format args
according to the format string fmt
, and write the result to the output iterator out
. At most n
characters are written. If present, loc
is used for locale-specific formatting.
Let CharT
be char for overloads (1,3), wchar_t for overloads (2,4).
These overloads participate in overload resolution only if
OutputIt
satisfies the concept std::output_iterator<const CharT&>.
The behavior is undefined if OutputIt
does not model (meet the semantic requirements of) the concept std::output_iterator<const CharT&>, or if std::formatter<std::remove_cvref_t<Ti>, CharT> does not meet the BasicFormatter requirements for any Ti
in Args
.
std::format_to_n_result
has no base classes, or members other than out
, size
and implicitly declared special member functions.Contents |
Parameters
out | - | iterator to the output buffer | ||||||||||||||||||||||||||||||||||||||||||||||
n | - | maximum number of characters to be written to the buffer | ||||||||||||||||||||||||||||||||||||||||||||||
fmt | - |
Each replacement field has the following format:
1) replacement field without a format specification
2) replacement field with a format specification
| ||||||||||||||||||||||||||||||||||||||||||||||
args... | - | arguments to be formatted | ||||||||||||||||||||||||||||||||||||||||||||||
loc | - | std::locale used for locale-specific formatting |
Return value
A format_to_n_result
such that the out
member is an iterator past the end of the output range, and the size
member is the total (not truncated) output size.
Exceptions
Propagates any exception thrown by formatter or iterator operations.
Example
At Godbolt's Compiler Explorer: clang (trunk) + libc++, gcc (trunk) + libstdc++.
#include <format> #include <iostream> #include <string_view> int main() { char buffer[64]; for (std::size_t max_chars_to_write : {std::size(buffer) - 1, 23uz}) { const auto result = std::format_to_n( buffer, max_chars_to_write, "Hubble's H{2} {3} {0}{4}{1} km/sec/Mpc.", // 24 bytes w/o formatters 71, // {0}, occupies 2 bytes 8, // {1}, occupies 1 byte "\u2080", // {2}, occupies 3 bytes, '₀' (SUBSCRIPT ZERO) "\u2245", // {3}, occupies 3 bytes, '≅' (APPROXIMATELY EQUAL TO) "\u00B1" // {4}, occupies 2 bytes, '±' (PLUS-MINUS SIGN) ); // 24 + 2 + 1 + 3 + 3 + 2 == 35, no trailing '\0' *result.out = '\0'; // adds terminator to buffer const std::string_view str{buffer, result.out}; // uses C++20 constructor std::cout << "Buffer until '\\0': \"" << str << "\"\n" << "Max chars to write: " << max_chars_to_write << '\n' << "result.out offset: " << result.out - buffer << '\n' << "Untruncated output size: " << result.size << "\n\n"; } }
Output:
Buffer until '\0': "Hubble's H₀ ≅ 71±8 km/sec/Mpc." Max chars to write: 63 result.out offset: 35 Untruncated output size: 35 Buffer until '\0': "Hubble's H₀ ≅ 71±8" Max chars to write: 23 result.out offset: 23 Untruncated output size: 35
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
P2216R3 | C++20 | throws std::format_error for invalid format string | invalid format string results in compile-time error |
P2418R2 | C++20 | objects that are neither const-usable nor copyable (such as generator-like objects) are not formattable |
allow formatting these objects |
P2508R1 | C++20 | there's no user-visible name for this facility | the name basic_format_string is exposed
|
See also
(C++20) |
stores formatted representation of the arguments in a new string (function template) |
(C++20) |
writes out formatted representation of its arguments through an output iterator (function template) |
(C++20) |
determines the number of characters necessary to store the formatted representation of its arguments (function template) |