From ac35dd5a6f8312005ab0d86cc4db28c20083af46 Mon Sep 17 00:00:00 2001 From: Charles Milette Date: Sun, 10 Jan 2021 18:26:24 -0500 Subject: [PATCH] Prevent integer overflows in wstr_to_utf8buf and utf8_to_wstrbuf --- include/spdlog/details/os-inl.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/spdlog/details/os-inl.h b/include/spdlog/details/os-inl.h index e37c0b97..50a6b5aa 100644 --- a/include/spdlog/details/os-inl.h +++ b/include/spdlog/details/os-inl.h @@ -436,7 +436,7 @@ SPDLOG_INLINE bool in_terminal(FILE *file) SPDLOG_NOEXCEPT #if (defined(SPDLOG_WCHAR_TO_UTF8_SUPPORT) || defined(SPDLOG_WCHAR_FILENAMES)) && defined(_WIN32) SPDLOG_INLINE void wstr_to_utf8buf(wstring_view_t wstr, memory_buf_t &target) { - if (wstr.size() > static_cast((std::numeric_limits::max)())) + if (wstr.size() > static_cast(std::numeric_limits::max()) / 2 - 1) { throw_spdlog_ex("UTF-16 string is too big to be converted to UTF-8"); } @@ -471,7 +471,7 @@ SPDLOG_INLINE void wstr_to_utf8buf(wstring_view_t wstr, memory_buf_t &target) SPDLOG_INLINE void utf8_to_wstrbuf(string_view_t str, wmemory_buf_t &target) { - if (str.size() > static_cast((std::numeric_limits::max)())) + if (str.size() > static_cast(std::numeric_limits::max()) - 1) { throw_spdlog_ex("UTF-8 string is too big to be converted to UTF-16"); }