OmniSciDB  b28c0d5765
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
logger::DebugTimer Class Reference

#include <Logger.h>

+ Collaboration diagram for logger::DebugTimer:

Public Member Functions

 DebugTimer (Severity, char const *file, int line, char const *name)
 
 ~DebugTimer ()
 
void stop ()
 
std::string stopAndGetJson ()
 

Private Member Functions

 DebugTimer (DebugTimer const &)=delete
 
 DebugTimer (DebugTimer &&)=delete
 
DebugTimeroperator= (DebugTimer const &)=delete
 
DebugTimeroperator= (DebugTimer &&)=delete
 

Private Attributes

Durationduration_
 

Detailed Description

Definition at line 320 of file Logger.h.

Constructor & Destructor Documentation

logger::DebugTimer::DebugTimer ( DebugTimer const &  )
privatedelete
logger::DebugTimer::DebugTimer ( DebugTimer &&  )
privatedelete
logger::DebugTimer::DebugTimer ( Severity  severity,
char const *  file,
int  line,
char const *  name 
)

Definition at line 762 of file Logger.cpp.

References nvtx_helpers::kDebugTimer, and nvtx_helpers::omnisci_range_push().

763  : duration_(newDuration(severity, file, line, name)) {
765 }
Duration * duration_
Definition: Logger.h:321
Duration * newDuration(Severity severity, Ts &&...args)
Definition: Logger.cpp:601
void omnisci_range_push(Category c, const char *name, const char *file)
tuple line
Definition: parse_ast.py:10
string name
Definition: setup.in.py:72

+ Here is the call graph for this function:

logger::DebugTimer::~DebugTimer ( )

Definition at line 767 of file Logger.cpp.

References nvtx_helpers::omnisci_range_pop(), and stop().

767  {
768  stop();
770 }
void omnisci_range_pop()

+ Here is the call graph for this function:

Member Function Documentation

DebugTimer& logger::DebugTimer::operator= ( DebugTimer const &  )
privatedelete
DebugTimer& logger::DebugTimer::operator= ( DebugTimer &&  )
privatedelete
void logger::DebugTimer::stop ( )

Definition at line 772 of file Logger.cpp.

References duration_, logger::logAndEraseDurationTree(), and logger::Duration::stop().

Referenced by ~DebugTimer().

772  {
773  if (duration_) {
774  if (duration_->stop()) {
775  logAndEraseDurationTree(nullptr);
776  }
777  duration_ = nullptr;
778  }
779 }
Duration * duration_
Definition: Logger.h:321
void logAndEraseDurationTree(std::string *json_str)
Definition: Logger.cpp:746

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

std::string logger::DebugTimer::stopAndGetJson ( )

Definition at line 781 of file Logger.cpp.

References duration_, json_str(), logger::logAndEraseDurationTree(), and logger::Duration::stop().

781  {
782  std::string json_str;
783  if (duration_) {
784  if (duration_->stop()) {
785  logAndEraseDurationTree(&json_str);
786  }
787  duration_ = nullptr;
788  }
789  return json_str;
790 }
const std::string json_str(const rapidjson::Value &obj) noexcept
Definition: JsonAccessors.h:44
Duration * duration_
Definition: Logger.h:321
void logAndEraseDurationTree(std::string *json_str)
Definition: Logger.cpp:746

+ Here is the call graph for this function:

Member Data Documentation

Duration* logger::DebugTimer::duration_
private

Definition at line 321 of file Logger.h.

Referenced by stop(), and stopAndGetJson().


The documentation for this class was generated from the following files: