From dc29b400e4d4011677d8d6ae8370c4a0f90601e6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Je=C5=99=C3=A1bek?= Date: Wed, 26 Jul 2023 18:00:58 +0200 Subject: [PATCH] expose detail::throw_format_error This enables to only #include when defining formatters. --- doc/api.rst | 4 ++-- include/fmt/core.h | 3 +++ 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/doc/api.rst b/doc/api.rst index ce4adb6a6b9a..47addf70fba2 100644 --- a/doc/api.rst +++ b/doc/api.rst @@ -124,7 +124,7 @@ parsing and formatting. To use this method specialize the ``formatter`` struct template for your type and implement ``parse`` and ``format`` methods. For example:: - #include + #include struct point { double x, y; @@ -156,7 +156,7 @@ For example:: if (it != end && (*it == 'f' || *it == 'e')) presentation = *it++; // Check if reached the end of the range: - if (it != end && *it != '}') throw format_error("invalid format"); + if (it != end && *it != '}') throw_format_error("invalid format"); // Return an iterator past the end of the parsed range: return it; diff --git a/include/fmt/core.h b/include/fmt/core.h index da96b68db97a..dfdb14507472 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -638,6 +638,9 @@ struct error_handler { }; } // namespace detail +/** Helper function to throw an error from a custom formatter. */ +using detail::throw_format_error; + /** String's character type. */ template using char_t = typename detail::char_t_impl::type;