From 12dfc91458df2378383c80ecaa7d7dd785461606 Mon Sep 17 00:00:00 2001 From: KjellKod Date: Thu, 11 Jul 2013 23:22:40 -0600 Subject: [PATCH] Bugfix: Thanks to Alexander Ignatyev. Now handles illegal, empty directory names. Bugfix: If directory path cannot be resolved it will as a last resort write the log to the current directory --- g2log/src/g2logworker.cpp | 38 +++++++++++++++++------------ g2log/test_unit/test_filechange.cpp | 1 + test_main/test_main.cpp | 1 - 3 files changed, 23 insertions(+), 17 deletions(-) diff --git a/g2log/src/g2logworker.cpp b/g2log/src/g2logworker.cpp index 76df032..f724d2f 100644 --- a/g2log/src/g2logworker.cpp +++ b/g2log/src/g2logworker.cpp @@ -73,23 +73,24 @@ std::string prefixSanityFix(std::string prefix) std::string pathSanityFix(std::string path, std::string file_name) { - // Unify the delimeters,. maybe sketchy solution but it seems to work - // on at least win7 + ubuntu. All bets are off for older windows - std::replace(path.begin(), path.end(), '\\', '/'); + // Unify the delimeters,. maybe sketchy solution but it seems to work + // on at least win7 + ubuntu. All bets are off for older windows + std::replace(path.begin(), path.end(), '\\', '/'); - // clean up in case of multiples - auto contains_end = [&](std::string& in) -> bool { - size_t size = in.size(); - if(!size) return false; - char end = in[size-1]; - return (end == '/' || end == ' '); - }; + // clean up in case of multiples + auto contains_end = [&](std::string& in) -> bool { + size_t size = in.size(); + if(!size) return false; + char end = in[size-1]; + return (end == '/' || end == ' '); + }; - while(contains_end(path)) - path.erase(path.size()-1); - path.insert(path.end(), '/'); // works on both unix and windows (win7, ubuntu) - path.insert(path.size(), file_name); - return path; + while(contains_end(path)) { path.erase(path.size()-1); } + if(!path.empty()) { + path.insert(path.end(), '/'); + } + path.insert(path.size(), file_name); + return path; } @@ -189,7 +190,12 @@ g2LogWorkerImpl::g2LogWorkerImpl(const std::string& log_prefix, const std::strin std::string file_name = createLogFileName(log_prefix_backup_); log_file_with_path_ = pathSanityFix(log_file_with_path_, file_name); outptr_ = createLogFile(log_file_with_path_); - assert((nullptr != outptr_) && "cannot open log file at startup"); + if(!outptr_) { + std::cerr << "Cannot write logfile to location, attempting current directory" << std::endl; + log_file_with_path_ = file_name; + outptr_ = createLogFile(log_file_with_path_); + } + assert((outptr_) && "cannot open log file at startup"); } diff --git a/g2log/test_unit/test_filechange.cpp b/g2log/test_unit/test_filechange.cpp index d9a5bd1..956aec7 100644 --- a/g2log/test_unit/test_filechange.cpp +++ b/g2log/test_unit/test_filechange.cpp @@ -109,6 +109,7 @@ std::string changeDirectoryOrName(std::string new_file_to_create) TEST(TestOf_GetFileName, Expecting_ValidLogFile) { + LOG(INFO) << "test_filechange, Retrieving file name: "; ASSERT_NE(g_logger_ptr, nullptr); std::future f_get_old_name = g_logger_ptr->logFileName(); diff --git a/test_main/test_main.cpp b/test_main/test_main.cpp index 87f7f6f..fabf9fd 100644 --- a/test_main/test_main.cpp +++ b/test_main/test_main.cpp @@ -6,7 +6,6 @@ #include #include -#include int main(int argc, char *argv[]) {