mirror of
https://github.com/vgough/encfs.git
synced 2024-11-29 19:33:49 +01:00
5f0806c5cc
git-vendor-name: easylogging git-vendor-dir: vendor/github.com/muflihun/easyloggingpp git-vendor-repository: https://github.com/muflihun/easyloggingpp git-vendor-ref: master
47 lines
1.4 KiB
C++
47 lines
1.4 KiB
C++
//
|
|
// This file is part of Easylogging++ samples
|
|
// PerformanceTrackingCallback sample
|
|
//
|
|
// Revision 1.0
|
|
// @author mkhan3189
|
|
//
|
|
|
|
#include "easylogging++.h"
|
|
|
|
INITIALIZE_EASYLOGGINGPP
|
|
class Handler : public el::PerformanceTrackingCallback {
|
|
protected:
|
|
void handle(const el::PerformanceTrackingData* data) {
|
|
// NEVER DO PERFORMANCE TRACKING FROM HANDLER
|
|
// TIMED_SCOPE(handBlock, "handerBlock");
|
|
|
|
// ELPP_COUT is cout when not using unicode otherwise wcout
|
|
ELPP_COUT << "I am from handler: " << data->blockName()->c_str() << " in " << *data->formattedTimeTaken();
|
|
if (data->dataType() == el::PerformanceTrackingData::DataType::Checkpoint) {
|
|
ELPP_COUT << " [CHECKPOINT ONLY] ";
|
|
}
|
|
ELPP_COUT << std::endl;
|
|
LOG(INFO) << "You can even log from here!";
|
|
}
|
|
};
|
|
|
|
int main(void) {
|
|
|
|
TIMED_SCOPE(mainBlock, "main");
|
|
|
|
el::Helpers::installPerformanceTrackingCallback<Handler>("handler");
|
|
|
|
TIMED_BLOCK(obj, "my-block") {
|
|
for (int i = 0; i <= 500; ++i) {
|
|
// Spend time
|
|
for (int j = 0; j < 10000; ++j) { std::string tmp; }
|
|
if (i % 100 == 0) {
|
|
obj.timer->checkpoint(std::string(std::string("checkpoint at ") + std::to_string(static_cast<unsigned long long>(i))).c_str());
|
|
}
|
|
}
|
|
}
|
|
LOG(INFO) << "By now, you should get performance result of above scope";
|
|
|
|
return 0;
|
|
}
|