5#include "MRPch/MRBindingMacros.h"
19 std::chrono::nanoseconds time = {};
20 double seconds()
const {
return time.count() * 1e-9; }
30 std::chrono::nanoseconds
myTime()
const {
return time - childTime(); }
32 double mySeconds()
const {
return myTime().count() * 1e-9; }
37 const char * threadName =
nullptr;
38 std::chrono::time_point<std::chrono::high_resolution_clock> started = std::chrono::high_resolution_clock::now();
39 bool printTreeInDtor =
true;
40 double minTimeSec = 0.1;
42 std::shared_ptr<spdlog::logger> loggerHandle = Logger::instance().getSpdLogger();
#define MRMESH_API
Definition MRMesh/MRMeshFwd.h:68
MR_BIND_IGNORE MRMESH_API void registerThreadRootTimeRecord(ThreadRootTimeRecord &root)
installs given record in the current thread (no record must be installed before)
MR_BIND_IGNORE MRMESH_API void unregisterThreadRootTimeRecord(ThreadRootTimeRecord &root)
un-installs given record in the current thread
Definition MRTimeRecord.h:17
double seconds() const
Definition MRTimeRecord.h:20
Definition MRTimeRecord.h:36
MRMESH_API ~ThreadRootTimeRecord()
MRMESH_API ThreadRootTimeRecord(const char *tdName)
MRMESH_API void printTree()
Definition MRTimeRecord.h:24
MRMESH_API std::chrono::nanoseconds childTime() const
double mySeconds() const
Definition MRTimeRecord.h:32
std::chrono::nanoseconds myTime() const
Definition MRTimeRecord.h:30
std::map< std::string, TimeRecord > children
Definition MRTimeRecord.h:26