From d3af1fe9fe5a7f015a4d8b21e0f29b1788bc993f Mon Sep 17 00:00:00 2001 From: himself65 Date: Mon, 30 Mar 2020 11:25:39 +0800 Subject: [PATCH] src: fix warnings on SPrintF PR-URL: https://github.com/nodejs/node/pull/32558 Reviewed-By: Anna Henningsen Reviewed-By: James M Snell --- src/debug_utils-inl.h | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/debug_utils-inl.h b/src/debug_utils-inl.h index 470fdc3db955c6..d87dd62c8952af 100644 --- a/src/debug_utils-inl.h +++ b/src/debug_utils-inl.h @@ -30,16 +30,17 @@ struct ToStringHelper { template ::value, int>::type = 0> - static std::string BaseConvert(T value) { + static std::string BaseConvert(const T& value) { + auto v = static_cast(value); char ret[3 * sizeof(T)]; char* ptr = ret + 3 * sizeof(T) - 1; *ptr = '\0'; const char* digits = "0123456789abcdef"; do { - unsigned digit = value & ((1 << BASE_BITS) - 1); + unsigned digit = v & ((1 << BASE_BITS) - 1); *--ptr = (BASE_BITS < 4 ? static_cast('0' + digit) : digits[digit]); - } while ((value >>= BASE_BITS) != 0); + } while ((v >>= BASE_BITS) != 0); return ptr; } template -std::string ToBaseString(T&& value) { - return ToStringHelper::BaseConvert(std::forward(value)); +std::string ToBaseString(const T& value) { + return ToStringHelper::BaseConvert(value); } inline std::string SPrintFImpl(const char* format) {