Commit 7bc598c9 authored by JamesReynolds's avatar JamesReynolds

Move errno code into common

errno code is no longer OS specific. Moving to common.
parent aa9012fa
...@@ -143,11 +143,6 @@ enum class pattern_time_type ...@@ -143,11 +143,6 @@ enum class pattern_time_type
// //
// Log exception // Log exception
// //
namespace details {
namespace os {
std::string errno_str(int err_num);
}
} // namespace details
class spdlog_ex : public std::exception class spdlog_ex : public std::exception
{ {
public: public:
...@@ -158,7 +153,15 @@ public: ...@@ -158,7 +153,15 @@ public:
spdlog_ex(const std::string &msg, int last_errno) spdlog_ex(const std::string &msg, int last_errno)
{ {
_msg = msg + ": " + details::os::errno_str(last_errno); char buf[256], *buf_ptr = buf;
SPDLOG_CONSTEXPR auto buf_size = sizeof(buf);
if (fmt::safe_strerror(last_errno, buf_ptr, buf_size) != 0)
{
buf_ptr = buf;
char unknown[] = "Unknown error";
std::copy(unknown, unknown + sizeof(unknown), buf_ptr);
}
_msg = msg + ": " + std::string(buf_ptr);
} }
const char *what() const SPDLOG_NOEXCEPT override const char *what() const SPDLOG_NOEXCEPT override
......
...@@ -383,18 +383,6 @@ inline std::string filename_to_str(const filename_t &filename) ...@@ -383,18 +383,6 @@ inline std::string filename_to_str(const filename_t &filename)
} }
#endif #endif
// Return errno string (thread safe)
inline std::string errno_str(int err_num)
{
char buf[256], *buf_ptr = buf;
SPDLOG_CONSTEXPR auto buf_size = sizeof(buf);
if (fmt::safe_strerror(err_num, buf_ptr, buf_size) == 0)
{
return std::string(buf_ptr);
}
return "Unknown error";
}
inline int pid() inline int pid()
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment