switch to new MPL based Fraunhofer FOKUS Public License
[senf.git] / senf / Utils / TypeInfo.cc
1 // $Id$
2 //
3 // Copyright (C) 2006
4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 //
6 // The contents of this file are subject to the Fraunhofer FOKUS Public License
7 // Version 1.0 (the "License"); you may not use this file except in compliance
8 // with the License. You may obtain a copy of the License at 
9 // http://senf.berlios.de/license.html
10 //
11 // The Fraunhofer FOKUS Public License Version 1.0 is based on, 
12 // but modifies the Mozilla Public License Version 1.1.
13 // See the full license text for the amendments.
14 //
15 // Software distributed under the License is distributed on an "AS IS" basis, 
16 // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 
17 // for the specific language governing rights and limitations under the License.
18 //
19 // The Original Code is Fraunhofer FOKUS code.
20 //
21 // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. 
22 // (registered association), Hansastraße 27 c, 80686 Munich, Germany.
23 // All Rights Reserved.
24 //
25 // Contributor(s):
26 //   Stefan Bund <g0dil@berlios.de>
27
28 /** \file
29     \brief TypeInfo non-inline non-template implementation */
30
31 #include "TypeInfo.hh"
32 //#include "TypeInfo.ih"
33
34 // Custom includes
35 #include <cxxabi.h>
36 #include <malloc.h>
37
38 //#include "TypeInfo.mpp"
39 #define prefix_
40 //-/////////////////////////////////////////////////////////////////////////////////////////////////
41
42 prefix_ std::string senf::prettyName(std::type_info const & type)
43 {
44     char const * mangled = type.name();
45     int status (0);
46     char * demangled ( abi::__cxa_demangle(mangled, 0, 0, &status) );
47     std::string name (demangled ? demangled : mangled);
48     if (demangled)
49         ::free(demangled);
50     return name;
51 }
52
53 prefix_ std::string senf::prettyBaseName(std::type_info const & type)
54 {
55     std::string name (prettyName(type));
56     std::string::size_type e (name.find('<'));
57     if (e == std::string::npos) e = name.size();
58     std::string::size_type b (name.rfind(':', e));
59     if (b == std::string::npos) b = 0; else ++b;
60     return name.substr(b,e-b);
61 }
62
63 //-/////////////////////////////////////////////////////////////////////////////////////////////////
64 #undef prefix_
65 //#include "TypeInfo.mpp"
66
67 \f
68 // Local Variables:
69 // mode: c++
70 // fill-column: 100
71 // c-file-style: "senf"
72 // indent-tabs-mode: nil
73 // ispell-local-dictionary: "american"
74 // compile-command: "scons -u test"
75 // comment-column: 40
76 // End: