From 5825d113fda97db913984ea0860c581e80e62cfc Mon Sep 17 00:00:00 2001 From: Roman Koshelev Date: Tue, 31 Aug 2021 07:51:06 +0300 Subject: [PATCH] Fix copy_str performance --- include/fmt/core.h | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/include/fmt/core.h b/include/fmt/core.h index 2f0cfb0b72c55..6de7f4f298e36 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -740,19 +740,26 @@ inline auto get_container(std::back_insert_iterator it) } template -FMT_CONSTEXPR auto copy_str(InputIt begin, InputIt end, OutputIt out) +FMT_CONSTEXPR auto copy_str_constexpr(InputIt begin, InputIt end, OutputIt out) -> OutputIt { while (begin != end) *out++ = static_cast(*begin++); return out; } -template ::value)> -FMT_CONSTEXPR auto copy_str(const Char* begin, const Char* end, Char* out) - -> Char* { +template +FMT_CONSTEXPR auto copy_str(InputIt begin, InputIt end, OutputIt out) + -> OutputIt { + return copy_str_constexpr(begin, end, out); +} + +template , U>::value && is_char::value)> +FMT_CONSTEXPR auto copy_str(T* begin, T* end, U* out) + -> U* { if (is_constant_evaluated()) - return copy_str(begin, end, out); + return copy_str_constexpr(begin, end, out); auto size = to_unsigned(end - begin); - memcpy(out, begin, size); + memcpy(out, begin, size * sizeof(U)); return out + size; }