10.1.1 - 2023-08-28

10.1.0 - 2023-08-12

10.0.0 - 2023-05-09

9.1.0 - 2022-08-27

9.0.0 - 2022-07-04

8.1.1 - 2022-01-06

8.1.0 - 2022-01-02

8.0.1 - 2021-07-02

8.0.0 - 2021-06-21

7.1.3 - 2020-11-24

7.1.2 - 2020-11-04

7.1.1 - 2020-11-01

7.1.0 - 2020-10-25

7.0.3 - 2020-08-06

7.0.2 - 2020-07-29

7.0.1 - 2020-07-07

7.0.0 - 2020-07-05

6.2.1 - 2020-05-09

6.2.0 - 2020-04-05

6.1.2 - 2019-12-11

6.1.1 - 2019-12-04

6.1.0 - 2019-12-01

6.0.0 - 2019-08-26

5.3.0 - 2018-12-28

5.2.1 - 2018-09-21

5.2.0 - 2018-09-13

5.1.0 - 2018-07-05

5.0.0 - 2018-05-21

4.1.0 - 2017-12-20

4.0.0 - 2017-06-27

3.0.2 - 2017-06-14

3.0.1 - 2016-11-01

3.0.0 - 2016-05-07

2.1.1 - 2016-04-11

2.1.0 - 2016-03-21

  • Project layout and build system improvements (https://github.com/fmtlib/fmt/pull/267):

    • The code have been moved to the cppformat directory. Including format.h from the top-level directory is deprecated but works via a proxy header which will be removed in the next major version.
    • C++ Format CMake targets now have proper interface definitions.
    • Installed version of the library now supports the header-only configuration.
    • Targets doc, install, and test are now disabled if C++ Format is included as a CMake subproject. They can be enabled by setting FMT_DOC, FMT_INSTALL, and FMT_TEST in the parent project.

    Thanks @niosHD.

2.0.1 - 2016-03-13

2.0.0 - 2015-12-01

General

Optimization

Distribution

Documentation

Fixes

1.1.0 - 2015-03-06

1.0.0 - 2015-02-05

0.12.0 - 2014-10-25

  • [Breaking] Improved separation between formatting and buffer management. Writer is now a base class that cannot be instantiated directly. The new MemoryWriter class implements the default buffer management with small allocations done on stack. So fmt::Writer should be replaced with fmt::MemoryWriter in variable declarations.

    Old code:

    fmt::Writer w;
    

    New code:

    fmt::MemoryWriter w;
    

    If you pass fmt::Writer by reference, you can continue to do so:

    void f(fmt::Writer &w);
    

    This doesn't affect the formatting API.

  • Support for custom memory allocators (https://github.com/fmtlib/fmt/issues/69)

  • Formatting functions now accept [signed char]{.title-ref} and [unsigned char]{.title-ref} strings as arguments (https://github.com/fmtlib/fmt/issues/73):

    auto s = format("GLSL version: {}", glGetString(GL_VERSION));
    
  • Reduced code bloat. According to the new benchmark results, cppformat is close to printf and by the order of magnitude better than Boost Format in terms of compiled code size.

  • Improved appearance of the documentation on mobile by using the Sphinx Bootstrap theme:

    OldNew

0.11.0 - 2014-08-21

  • Safe printf implementation with a POSIX extension for positional arguments:

    fmt::printf("Elapsed time: %.2f seconds", 1.23);
    fmt::printf("%1$s, %3$d %2$s", weekday, month, day);
    
  • Arguments of char type can now be formatted as integers (Issue https://github.com/fmtlib/fmt/issues/55):

    fmt::format("0x{0:02X}", 'a');
    
  • Deprecated parts of the API removed.

  • The library is now built and tested on MinGW with Appveyor in addition to existing test platforms Linux/GCC, OS X/Clang, Windows/MSVC.

0.10.0 - 2014-07-01

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 the FMT_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 lightweight, 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 of std::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 https://github.com/fmtlib/fmt/issues/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 and A:

    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 - 2014-05-13

  • 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 returns Writer instead of std::string. Use the str function to convert it to std::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 throws SystemError containing the formatted message and system-specific error description. For example, the following code

    FILE *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 throws SystemError in case of I/O errors.

  • Improve test infrastructure. Print functions are now tested by redirecting the output to a pipe.

0.8.0 - 2014-04-14

  • Initial release