Commit 47006c4e authored by Gabi Melman's avatar Gabi Melman Committed by GitHub

Merge pull request #436 from bahostetterlewis/master

Allow compiler to select an strerror_r stringify
parents e9b82867 84a4f56e
...@@ -364,6 +364,17 @@ inline std::string filename_to_str(const filename_t& filename) ...@@ -364,6 +364,17 @@ inline std::string filename_to_str(const filename_t& filename)
} }
#endif #endif
inline std::string errno_to_string(char [256], char* res) {
return std::string(res);
}
inline std::string errno_to_string(char buf[256], int res) {
if (res == 0) {
return std::string(buf);
} else {
return "Unknown error";
}
}
// Return errno string (thread safe) // Return errno string (thread safe)
inline std::string errno_str(int err_num) inline std::string errno_str(int err_num)
...@@ -386,7 +397,8 @@ inline std::string errno_str(int err_num) ...@@ -386,7 +397,8 @@ inline std::string errno_str(int err_num)
return "Unknown error"; return "Unknown error";
#else // gnu version (might not use the given buf, so its retval pointer must be used) #else // gnu version (might not use the given buf, so its retval pointer must be used)
return std::string(strerror_r(err_num, buf, buf_size)); auto err = strerror_r(err_num, buf, buf_size); // let compiler choose type
return errno_to_string(buf, err); // use overloading to select correct stringify function
#endif #endif
} }
......
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