mirror of
https://github.com/vgough/encfs.git
synced 2024-11-25 09:23:13 +01:00
39 lines
1.1 KiB
C++
39 lines
1.1 KiB
C++
|
//
|
||
|
// This file is part of Easylogging++ samples
|
||
|
//
|
||
|
// Demonstration on possible usage of pre-rollout handler
|
||
|
//
|
||
|
// Revision: 1.1
|
||
|
// @author mkhan3189
|
||
|
//
|
||
|
|
||
|
#include "easylogging++.h"
|
||
|
|
||
|
INITIALIZE_EASYLOGGINGPP
|
||
|
|
||
|
static unsigned int idx;
|
||
|
|
||
|
void rolloutHandler(const char* filename, std::size_t size) {
|
||
|
// SHOULD NOT LOG ANYTHING HERE BECAUSE LOG FILE IS CLOSED!
|
||
|
std::cout << "************** Rolling out [" << filename << "] because it reached [" << size << " bytes]" << std::endl;
|
||
|
|
||
|
// BACK IT UP
|
||
|
std::stringstream ss;
|
||
|
ss << "mv " << filename << " bin/log-backup-" << ++idx;
|
||
|
system(ss.str().c_str());
|
||
|
}
|
||
|
|
||
|
int main(int, char**) {
|
||
|
idx = 0;
|
||
|
el::Loggers::addFlag(el::LoggingFlag::StrictLogFileSizeCheck);
|
||
|
el::Loggers::reconfigureAllLoggers(el::ConfigurationType::Filename, "/tmp/logs/max-size.log");
|
||
|
el::Loggers::reconfigureAllLoggers(el::ConfigurationType::MaxLogFileSize, "100");
|
||
|
el::Helpers::installPreRollOutCallback(rolloutHandler);
|
||
|
|
||
|
for (int i = 0; i < 100; ++i)
|
||
|
LOG(INFO) << "Test";
|
||
|
|
||
|
el::Helpers::uninstallPreRollOutCallback();
|
||
|
return 0;
|
||
|
}
|