From c86fe0b8d3aa6553160ad04aed608c2e694e9136 Mon Sep 17 00:00:00 2001 From: Minty-Meeo <45425365+Minty-Meeo@users.noreply.github.com> Date: Tue, 13 Jun 2023 03:22:19 -0500 Subject: [PATCH] Give basic_memory_buffer allocator [[no_unique_address]] (#3485) This allows stateless allocators to take up no space while still avoiding the empty base class optimization. --- include/fmt/format.h | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/include/fmt/format.h b/include/fmt/format.h index 67d9caffde64..3bba5c59c3f0 100644 --- a/include/fmt/format.h +++ b/include/fmt/format.h @@ -79,6 +79,18 @@ # endif #endif +#ifndef FMT_NO_UNIQUE_ADDRESS +# if FMT_CPLUSPLUS >= 202002L +# if FMT_HAS_CPP_ATTRIBUTE(no_unique_address) +# define FMT_NO_UNIQUE_ADDRESS [[no_unique_address]] +# elif FMT_MSC_VERSION >= 1929 // VS2019 v16.10 and later +# define FMT_NO_UNIQUE_ADDRESS [[msvc::no_unique_address]] +# endif +# else +# define FMT_NO_UNIQUE_ADDRESS +# endif +#endif + #if FMT_GCC_VERSION || defined(__clang__) # define FMT_VISIBILITY(value) __attribute__((visibility(value))) #else @@ -920,7 +932,7 @@ class basic_memory_buffer final : public detail::buffer { T store_[SIZE]; // Don't inherit from Allocator avoid generating type_info for it. - Allocator alloc_; + FMT_NO_UNIQUE_ADDRESS Allocator alloc_; // Deallocate memory allocated by the buffer. FMT_CONSTEXPR20 void deallocate() {