From 4deb2510711134a0fb40cb4295cc39b942f43dff Mon Sep 17 00:00:00 2001 From: Andre Puschmann Date: Tue, 3 Jul 2018 13:09:43 +0200 Subject: [PATCH] remove duplicate run-state variable in logger_file --- lib/include/srslte/common/logger_file.h | 3 +-- lib/src/common/logger_file.cc | 20 ++++++++------------ 2 files changed, 9 insertions(+), 14 deletions(-) diff --git a/lib/include/srslte/common/logger_file.h b/lib/include/srslte/common/logger_file.h index f0bd5a15b..f4bfd4582 100644 --- a/lib/include/srslte/common/logger_file.h +++ b/lib/include/srslte/common/logger_file.h @@ -64,8 +64,7 @@ private: int64_t max_length; int64_t cur_length; FILE* logfile; - bool inited; - bool not_done; + bool is_running; std::string filename; pthread_cond_t not_empty; pthread_cond_t not_full; diff --git a/lib/src/common/logger_file.cc b/lib/src/common/logger_file.cc index e8c60dcdb..12fcbb3ba 100644 --- a/lib/src/common/logger_file.cc +++ b/lib/src/common/logger_file.cc @@ -34,18 +34,17 @@ using namespace std; namespace srslte{ logger_file::logger_file() - :inited(false) - ,logfile(NULL) - ,not_done(true) + :logfile(NULL) + ,is_running(false) ,cur_length(0) ,max_length(0) {} logger_file::~logger_file() { - not_done = false; - if(inited) { + if(is_running) { log(new std::string("Closing log\n")); pthread_mutex_lock(&mutex); + is_running = false; pthread_cond_signal(¬_empty); // wakeup thread and let it terminate pthread_mutex_unlock(&mutex); wait_thread_finish(); @@ -67,11 +66,11 @@ void logger_file::init(std::string file, int max_length_) { name_idx = 0; filename = file; logfile = fopen(filename.c_str(), "w"); - if(logfile==NULL) { + if(logfile == NULL) { printf("Error: could not create log file, no messages will be logged!\n"); } + is_running = true; start(-2); - inited = true; } void logger_file::log(const char *msg) { @@ -86,14 +85,11 @@ void logger_file::log(str_ptr msg) { } void logger_file::run_thread() { - while(not_done) { + while(is_running) { pthread_mutex_lock(&mutex); while(buffer.empty()) { pthread_cond_wait(¬_empty, &mutex); - if(not_done == false) // Thread done. Messages in buffer will be handled in flush. - { - return; - } + if(!is_running) return; // Thread done. Messages in buffer will be handled in flush. } str_ptr s = buffer.front(); pthread_cond_signal(¬_full);