Libcwd reads the symbol table of the application and of each of the linked object files upon initialization. It then allows you to translate program counter addresses to function names, source file names and line numbers. You can also print demangled names of any symbol or type, making the debug output better human readable.
Example 1: printing the location that a function was called from:#ifdef CWDEBUG
std::string demangled_function_name;
Dout(
dc::notice,
"This function was called from " << demangled_function_name <<
'(' << location <<
')');
#endif
Example 2: Printing the demangled name of the current (template) function:
Dout(
dc::notice,
"We are in Foo<" << type_info_of<TYPE>().demangled_name() <<
">::f()");
Note that calling demangle_symbol costs cpu every time you call it, but using type_info_of<> does not cost any cpu: the demangling is done once, during the initialization of libcwd; type_info_of<> merely returns a static pointer.