libzypp
10.5.0
|
A simple tracer for (copy) Construction, Assignment, and Destruction. More...
#include <Debug.h>
Public Member Functions | |
TraceCAD () | |
TraceCAD (const TraceCAD &rhs) | |
TraceCAD & | operator= (const TraceCAD &rhs) |
virtual | ~TraceCAD () |
void | _PING () const |
Static Public Member Functions | |
static unsigned long & | _totalTraceCAD () |
Related Functions | |
(Note that these are not member functions.) | |
template<class _Tp > | |
std::ostream & | operator<< (std::ostream &str, const TraceCAD< _Tp > &obj) |
A simple tracer for (copy) Construction, Assignment, and Destruction.
To trace class Foo, derive public from TraceCAD<Foo>. This tracer simply calls traceCAD in each traced method, and traceCAD simply drops a line in the log.
This tracer logs construction, copy construction, assignment, destruction and _PING.
assignment: In case the traced class defines an operator= it must be altered to call TraceCAD::operator=, otherwise it won't be triggered.
_PING: Completely up to you. Call _PING somewhere in the traced class to indicate something. In case you overload traceCAD, do whatever is appropriate on _PING. It's just an offer to perform logging or actions here, and not in the traced code.
But traceCAD may be overloaded to produce more stats.
Example.COW_debug.cc
. zypp::debug::TraceCAD< _Tp >::TraceCAD | ( | ) | [inline] |
zypp::debug::TraceCAD< _Tp >::TraceCAD | ( | const TraceCAD< _Tp > & | rhs | ) | [inline] |
virtual zypp::debug::TraceCAD< _Tp >::~TraceCAD | ( | ) | [inline, virtual] |
static unsigned long& zypp::debug::TraceCAD< _Tp >::_totalTraceCAD | ( | ) | [inline, static] |
TraceCAD& zypp::debug::TraceCAD< _Tp >::operator= | ( | const TraceCAD< _Tp > & | rhs | ) | [inline] |
void zypp::debug::TraceCAD< _Tp >::_PING | ( | ) | const [inline] |