From 60c662b3a72b4b17bcff92ec17482259150676a0 Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Sun, 8 Jul 2018 15:00:44 -0700 Subject: [PATCH] Add an example of reusing formatters --- doc/api.rst | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/doc/api.rst b/doc/api.rst index f41b840f..1435cca1 100644 --- a/doc/api.rst +++ b/doc/api.rst @@ -130,6 +130,25 @@ always be formatted in the same way. See ``formatter::parse`` in :file:`fmt/time.h` for an advanced example of how to parse the format string and customize the formatted output. +You can also reuse existing formatters, for example:: + + enum color {red, green, blue}; + + template <> + struct fmt::formatter: formatter { + // parse is inherited from formatter. + template + auto format(color c, FormatContext &ctx) { + string_view name = "unknown"; + switch (c) { + case red: name = "red"; break; + case green: name = "green"; break; + case blue: name = "blue"; break; + } + return formatter::format(name, ctx); + } + }; + This section shows how to define a custom format function for a user-defined type. The next section describes how to get ``fmt`` to use a conventional stream output ``operator<<`` when one is defined for a user-defined type.