X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2FTypeInfo.cc;h=bed28764c3f9d6595abfd8297b278f063bfa45ea;hb=412024ed31a4ab4eaea7a4165a434f8efebee325;hp=1c1825604c6a4b5e50d83121839a960851aba54c;hpb=be33ff96c5b89738694da272d8610564cce48bfb;p=senf.git diff --git a/Utils/TypeInfo.cc b/Utils/TypeInfo.cc index 1c18256..bed2876 100644 --- a/Utils/TypeInfo.cc +++ b/Utils/TypeInfo.cc @@ -27,27 +27,18 @@ //#include "TypeInfo.ih" // Custom includes -#include "malloc.h" - -// Copied from the binutils sources -#define HAVE_DECL_BASENAME 1 -#define HAVE_DECL_ASPRINTF 1 -#define HAVE_DECL_VASPRINTF 1 -#include "impl/demangle.h" +#include +#include //#include "TypeInfo.mpp" #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// - -// WARNING: This is completely g++ and libiberty dependent. The demangling -// interface isn't even explicitly exportet from libiberty. However, it is -// *EXTREMELY* helpful for debugging ... - prefix_ std::string senf::prettyName(std::type_info const & type) { char const * mangled = type.name(); - char * demangled = ::cplus_demangle(mangled,DMGL_TYPES|DMGL_AUTO); + int status (0); + char * demangled ( abi::__cxa_demangle(mangled, 0, 0, &status) ); std::string name (demangled ? demangled : mangled); if (demangled) ::free(demangled);