Support grouped writing delayed by time
This commit is contained in:
parent
cef9c64e86
commit
108e42ce1f
5
.vscode/settings.json
vendored
5
.vscode/settings.json
vendored
@ -5,6 +5,9 @@
|
|||||||
"fstream": "cpp",
|
"fstream": "cpp",
|
||||||
"*.tcc": "cpp",
|
"*.tcc": "cpp",
|
||||||
"ostream": "cpp",
|
"ostream": "cpp",
|
||||||
"mutex": "cpp"
|
"mutex": "cpp",
|
||||||
|
"queue": "cpp",
|
||||||
|
"array": "cpp",
|
||||||
|
"string_view": "cpp"
|
||||||
}
|
}
|
||||||
}
|
}
|
18
lib/log.hpp
18
lib/log.hpp
@ -9,6 +9,7 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
#include <queue>
|
||||||
|
|
||||||
#if _WIN32
|
#if _WIN32
|
||||||
typedef unsigned int uint;
|
typedef unsigned int uint;
|
||||||
@ -39,6 +40,9 @@ class log {
|
|||||||
uint day;
|
uint day;
|
||||||
string path;
|
string path;
|
||||||
mutex io;
|
mutex io;
|
||||||
|
uint32_t groupedWriting;
|
||||||
|
time_t lastWriting;
|
||||||
|
queue<string> toWrite;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checking if the path is in the string dir directory
|
* Checking if the path is in the string dir directory
|
||||||
@ -75,6 +79,18 @@ class log {
|
|||||||
*/
|
*/
|
||||||
void put(string logline, Level _level);
|
void put(string logline, Level _level);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write to log file
|
||||||
|
*/
|
||||||
|
|
||||||
|
void write(string logline);
|
||||||
|
|
||||||
|
void midnight();
|
||||||
|
|
||||||
|
void writeQueue();
|
||||||
|
|
||||||
|
bool writableQueue();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -83,7 +99,7 @@ class log {
|
|||||||
* optional: a bool variable if it keeps the file open,
|
* optional: a bool variable if it keeps the file open,
|
||||||
* and a bool variable if it prints log lines to the console
|
* and a bool variable if it prints log lines to the console
|
||||||
*/
|
*/
|
||||||
log (string _dir, Level loglevel = WARNING, bool _isKeepOpen = true, bool _printInConsole = false);
|
log (string _dir, Level loglevel = WARNING, bool _isKeepOpen = true, bool _printInConsole = false, uint32_t groupedWriting = 0);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
70
src/log.cpp
70
src/log.cpp
@ -3,11 +3,12 @@
|
|||||||
namespace marcelb {
|
namespace marcelb {
|
||||||
namespace logging {
|
namespace logging {
|
||||||
|
|
||||||
log::log(string _dir, Level _loglevel, bool _isKeepOpen, bool _printInConsole) {
|
log::log(string _dir, Level _loglevel, bool _isKeepOpen, bool _printInConsole, uint32_t _groupedWriting) {
|
||||||
dir = _dir;
|
dir = _dir;
|
||||||
loglevel = _loglevel;
|
loglevel = _loglevel;
|
||||||
isKeepOpen = _isKeepOpen;
|
isKeepOpen = _isKeepOpen;
|
||||||
printInConsole = _printInConsole;
|
printInConsole = _printInConsole;
|
||||||
|
groupedWriting = _groupedWriting;
|
||||||
|
|
||||||
if (!isdir()) {
|
if (!isdir()) {
|
||||||
throw string("[ERROR] Log dir path invalid ");
|
throw string("[ERROR] Log dir path invalid ");
|
||||||
@ -15,6 +16,9 @@ log::log(string _dir, Level _loglevel, bool _isKeepOpen, bool _printInConsole) {
|
|||||||
|
|
||||||
setMoment();
|
setMoment();
|
||||||
day = moment->tm_mday;
|
day = moment->tm_mday;
|
||||||
|
if (groupedWriting) {
|
||||||
|
lastWriting = timelocal(moment);
|
||||||
|
}
|
||||||
setPath();
|
setPath();
|
||||||
|
|
||||||
if (isKeepOpen) {
|
if (isKeepOpen) {
|
||||||
@ -57,20 +61,21 @@ void log::put(string logline, Level _level) {
|
|||||||
|
|
||||||
setMoment();
|
setMoment();
|
||||||
setPrefix(logline, _level);
|
setPrefix(logline, _level);
|
||||||
|
midnight();
|
||||||
|
|
||||||
if (day != moment->tm_mday) {
|
if (groupedWriting) {
|
||||||
if (isKeepOpen && logfile.is_open()) {
|
toWrite.push(logline);
|
||||||
loose();
|
if (writableQueue()) {
|
||||||
}
|
writeQueue();
|
||||||
day = moment->tm_mday;
|
|
||||||
setPath();
|
|
||||||
if (isKeepOpen) {
|
|
||||||
if (!open()) {
|
|
||||||
throw string("[ERROR] Opening log file! ");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
write(logline);
|
||||||
}
|
}
|
||||||
|
io.unlock();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void log::write(string logline) {
|
||||||
if (!isKeepOpen || !logfile.is_open()) {
|
if (!isKeepOpen || !logfile.is_open()) {
|
||||||
if (!open()) {
|
if (!open()) {
|
||||||
throw string("[ERROR] Opening log file! ");
|
throw string("[ERROR] Opening log file! ");
|
||||||
@ -82,8 +87,49 @@ void log::put(string logline, Level _level) {
|
|||||||
if (!isKeepOpen && logfile.is_open()) {
|
if (!isKeepOpen && logfile.is_open()) {
|
||||||
loose();
|
loose();
|
||||||
}
|
}
|
||||||
io.unlock();
|
}
|
||||||
|
|
||||||
|
void log::midnight() {
|
||||||
|
if (day != moment->tm_mday) {
|
||||||
|
if (groupedWriting && !toWrite.empty()) {
|
||||||
|
writeQueue();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isKeepOpen && logfile.is_open()) {
|
||||||
|
loose();
|
||||||
|
}
|
||||||
|
day = moment->tm_mday;
|
||||||
|
setPath();
|
||||||
|
if (isKeepOpen) {
|
||||||
|
if (!open()) {
|
||||||
|
throw string("[ERROR] Opening log file! ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void log::writeQueue() {
|
||||||
|
string lines;
|
||||||
|
bool notEmpty = !toWrite.empty();
|
||||||
|
|
||||||
|
while (notEmpty) {
|
||||||
|
lines += toWrite.front();
|
||||||
|
toWrite.pop();
|
||||||
|
notEmpty = !toWrite.empty();
|
||||||
|
if (notEmpty) lines += "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
write(lines);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool log::writableQueue() {
|
||||||
|
bool _writable = false;
|
||||||
|
auto _time = timelocal(moment);
|
||||||
|
if (_time > lastWriting + groupedWriting) {
|
||||||
|
_writable = true;
|
||||||
|
lastWriting = _time;
|
||||||
|
}
|
||||||
|
return _writable;
|
||||||
}
|
}
|
||||||
|
|
||||||
void log::setPath() {
|
void log::setPath() {
|
||||||
|
@ -1,18 +1,25 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "../lib/log.hpp"
|
#include "../lib/log.hpp"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace marcelb::logging;
|
using namespace marcelb::logging;
|
||||||
|
|
||||||
log mylog("../example", Level::INFO, false);
|
log mylog("../example", Level::DEBUG, true, false, 5);
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
mylog.debug("Start debug loging");
|
// mylog.debug("Start debug loging");
|
||||||
mylog.info("Start info loging");
|
// mylog.info("Start info loging");
|
||||||
mylog.warning("Start warning loging");
|
// mylog.warning("Start warning loging");
|
||||||
mylog.error("Start error loging");
|
// mylog.error("Start error loging");
|
||||||
mylog.fatal("Start fatal loging");
|
// mylog.fatal("Start fatal loging");
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
while(true) {
|
||||||
|
mylog.fatal("Test fatal error: "+ to_string(i++));
|
||||||
|
sleep(2);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user