From 13860e8234b978f3216a2dcdbc78dcb2513be921 Mon Sep 17 00:00:00 2001 From: Justin Riddell Date: Sun, 7 Jul 2024 19:28:46 +0100 Subject: [PATCH] Support printing (const) volatile void* Fixes #4049 --- include/fmt/base.h | 6 ++++++ test/base-test.cc | 15 +++++++++++++++ 2 files changed, 21 insertions(+) diff --git a/include/fmt/base.h b/include/fmt/base.h index ceb9845591ebe..c95ca6a48ca73 100644 --- a/include/fmt/base.h +++ b/include/fmt/base.h @@ -1476,6 +1476,12 @@ template struct arg_mapper { FMT_MAP_API auto map(void* val) -> const void* { return val; } FMT_MAP_API auto map(const void* val) -> const void* { return val; } + FMT_MAP_API auto map(volatile void* val) -> const void* { + return const_cast(val); + } + FMT_MAP_API auto map(const volatile void* val) -> const void* { + return const_cast(val); + } FMT_MAP_API auto map(std::nullptr_t val) -> const void* { return val; } // Use SFINAE instead of a const T* parameter to avoid a conflict with the diff --git a/test/base-test.cc b/test/base-test.cc index c82e7378cd94d..15230478bd431 100644 --- a/test/base-test.cc +++ b/test/base-test.cc @@ -425,6 +425,21 @@ TEST(arg_test, pointer_arg) { CHECK_ARG_SIMPLE(cp); } +TEST(arg_test, volatile_pointer_arg) { + auto check = [](const int val) { + CHECK_ARG( + char, reinterpret_cast(val), + static_cast(reinterpret_cast(val))); + CHECK_ARG(char, reinterpret_cast(val), + static_cast( + reinterpret_cast(val))); + }; + check(0); + check(1); + check(2); + check(0xdeadbeef); +} + struct check_custom { auto operator()(fmt::basic_format_arg::handle h) const -> test_result {