Releases: fmtlib/fmt
0.10.0
Improved API
-
All formatting methods are now implemented as variadic functions instead of using
operator<<
for feeding arbitrary arguments into a temporary formatter object. This works both with C++11 where variadic templates are used and with older standards where variadic functions are emulated by providing lightweight wrapper functions defined with theFMT_VARIADIC
macro. You can use this macro for defining your own portable variadic functions:void report_error(const char *format, const fmt::ArgList &args) { fmt::print("Error: {}"); fmt::print(format, args); } FMT_VARIADIC(void, report_error, const char *) report_error("file not found: {}", path);
Apart from a more natural syntax, this also improves performance as there is no need to construct temporary formatter objects and control arguments' lifetimes. Because the wrapper functions are very ligthweight, this doesn't cause code bloat even in pre-C++11 mode.
-
Simplified common case of formatting an
std::string
. Now it requires a single function call:std::string s = format("The answer is {}.", 42);
Previously it required 2 function calls:
std::string s = str(Format("The answer is {}.") << 42);
Instead of unsafe
c_str
function,fmt::Writer
should be used directly to bypass creation ofstd::string
:fmt::Writer w; w.write("The answer is {}.", 42); w.c_str(); // returns a C string
This doesn't do dynamic memory allocation for small strings and is less error prone as the lifetime of the string is the same as for
std::string::c_str
which is well understood (hopefully). -
Improved consistency in naming functions that are a part of the public API. Now all public functions are lowercase following the standard library conventions. Previously it was a combination of lowercase and CapitalizedWords. Issue #50.
-
Old functions are marked as deprecated and will be removed in the next release.
Other Changes
-
Experimental support for printf format specifications (work in progress):
fmt::printf("The answer is %d.", 42); std::string s = fmt::sprintf("Look, a %s!", "string");
-
Support for hexadecimal floating point format specifiers
a
andA
:print("{:a}", -42.0); // Prints -0x1.5p+5 print("{:A}", -42.0); // Prints -0X1.5P+5
-
CMake option
FMT_SHARED
that specifies whether to build format as a shared library (off by default).
0.9.0
-
More efficient implementation of variadic formatting functions.
-
Writer::Format
now has a variadic overload:Writer out; out.Format("Look, I'm {}!", "variadic");
-
For efficiency and consistency with other overloads, variadic overload of the
Format
function now returnsWriter
instead ofstd::string
. Use thestr
function to convert it tostd::string
:std::string s = str(Format("Look, I'm {}!", "variadic"));
-
Replaced formatter actions with output sinks:
NoAction
->NullSink
,Write
->FileSink
,ColorWriter
->ANSITerminalSink
. This improves naming consistency and shouldn't affect client code unless these classes are used directly which should be rarely needed. -
Added
ThrowSystemError
function that formats a message and throwsSystemError
containing the formatted message and system-specific error description. For example, the following codeFILE *f = fopen(filename, "r"); if (!f) ThrowSystemError(errno, "Failed to open file '{}'") << filename;
will throw
SystemError
exception with description"Failed to open file '<filename>': No such file or directory"
if file doesn't exist. -
Support for AppVeyor continuous integration platform.
-
Format
now throwsSystemError
in case of I/O errors. -
Improve test infrastructure. Print functions are now tested by redirecting the output to a pipe.