mirror of
https://github.com/thooge/esp32-nmea2000-obp60.git
synced 2025-12-16 07:23:07 +01:00
make logging thread safe
This commit is contained in:
@@ -12,27 +12,37 @@ GwLog::GwLog(int level, GwLogWriter *writer){
|
||||
logLevel=level;
|
||||
if (writer == NULL) writer=new DefaultLogWriter();
|
||||
this->writer=writer;
|
||||
locker = xSemaphoreCreateMutex();
|
||||
}
|
||||
GwLog::~GwLog(){
|
||||
vSemaphoreDelete(locker);
|
||||
}
|
||||
void GwLog::logString(const char *fmt,...){
|
||||
if (! writer) return;
|
||||
va_list args;
|
||||
va_start(args,fmt);
|
||||
xSemaphoreTake(locker, portMAX_DELAY);
|
||||
vsnprintf(buffer,99,fmt,args);
|
||||
if (! writer) return;
|
||||
writer->write(prefix.c_str());
|
||||
writer->write(buffer);
|
||||
writer->write("\n");
|
||||
xSemaphoreGive(locker);
|
||||
}
|
||||
void GwLog::logDebug(int level,const char *fmt,...){
|
||||
if (level > logLevel) return;
|
||||
if (! writer) return;
|
||||
va_list args;
|
||||
va_start(args,fmt);
|
||||
xSemaphoreTake(locker, portMAX_DELAY);
|
||||
vsnprintf(buffer,99,fmt,args);
|
||||
if (! writer) return;
|
||||
writer->write(prefix.c_str());
|
||||
writer->write(buffer);
|
||||
writer->write("\n");
|
||||
xSemaphoreGive(locker);
|
||||
}
|
||||
void GwLog::setWriter(GwLogWriter *writer){
|
||||
xSemaphoreTake(locker, portMAX_DELAY);
|
||||
if (this->writer) delete this->writer;
|
||||
this->writer=writer;
|
||||
xSemaphoreGive(locker);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user