Skip to content

Commit

Permalink
feat: fill char buffer with null char
Browse files Browse the repository at this point in the history
those funcs always return null-terminated string but just to make it
sure
  • Loading branch information
ToruNiina committed Oct 10, 2023
1 parent 947c995 commit 937a7c4
Showing 1 changed file with 3 additions and 0 deletions.
3 changes: 3 additions & 0 deletions toml/exception.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ inline std::string str_error(int errnum)
#ifdef _MSC_VER // MSVC
constexpr std::size_t bufsize = 256;
std::array<char, bufsize> buf;
buf.fill('\0');
const auto result = strerror_s(buf.data(), bufsize, errnum);
if(result != 0)
{
Expand All @@ -39,11 +40,13 @@ inline std::string str_error(int errnum)
#elif defined(_GNU_SOURCE)
constexpr std::size_t bufsize = 256;
std::array<char, bufsize> buf;
buf.fill('\0');
const char* result = strerror_r(errnum, buf.data(), bufsize);
return std::string(result);
#elif (defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE >= 200112L) || (defined(_XOPEN_SOURCE) && _XOPEN_SOURCE >= 600)
constexpr std::size_t bufsize = 256;
std::array<char, bufsize> buf;
buf.fill('\0');
const int result = strerror_r(errnum, buf.data(), bufsize);
if (result != 0)
{
Expand Down

0 comments on commit 937a7c4

Please sign in to comment.