JeVois
1.20
JeVois Smart Embedded Machine Vision Toolkit
Share this page:
Tweet
Demangle.H
Go to the documentation of this file.
1
// ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
2
//
3
// JeVois Smart Embedded Machine Vision Toolkit - Copyright (C) 2016 by Laurent Itti, the University of Southern
4
// California (USC), and iLab at USC. See http://iLab.usc.edu and http://jevois.org for information about this project.
5
//
6
// This file is part of the JeVois Smart Embedded Machine Vision Toolkit. This program is free software; you can
7
// redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software
8
// Foundation, version 2. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
9
// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
10
// License for more details. You should have received a copy of the GNU General Public License along with this program;
11
// if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
12
//
13
// Contact information: Laurent Itti - 3641 Watt Way, HNB-07A - Los Angeles, CA 90089-2520 - USA.
14
// Tel: +1 213 740 3527 - itti@pollux.usc.edu - http://iLab.usc.edu - http://jevois.org
15
// ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
16
/*! \file */
17
18
// This code is inspired by the Neuromorphic Robotics Toolkit (http://nrtkit.org)
19
20
#pragma once
21
22
#include <string>
23
#include <typeinfo>
24
25
namespace
jevois
26
{
27
/*! \defgroup demangling Name demangling functions
28
29
Name demangling functions return the original name of a type as written in the source code, as opposed to the name
30
used internally by the compiler, which is mangled to avoid name conflicts and confusions across different
31
namespaces, overloads, and such.
32
33
See http://en.wikipedia.org/wiki/Name_mangling for more information.
34
35
\ingroup utils */
36
37
/*! @{ */
// **********************************************************************
38
39
//! Demangle a mangled name
40
std::string
demangle
(std::string
const
& mangledName);
41
42
//! Demangle a mangled name
43
std::string
demangle
(
char
const
* mangledName);
44
45
//! Get the demangled type name of type T
46
template
<
typename
T>
47
std::string
demangledName
();
48
49
//! Specialization for std::string to avoid getting an ugly name
50
template
<>
51
std::string demangledName<std::string>();
52
53
/*! @} */
// **********************************************************************
54
55
}
// namespace jevois
56
57
// Include implementation details of no interest to end users
58
#include <jevois/Util/details/DemangleImpl.H>
jevois
Definition:
Concepts.dox:1
jevois::demangledName
std::string demangledName()
Get the demangled type name of type T.
jevois::demangle
std::string demangle(std::string const &mangledName)
Demangle a mangled name.
include
jevois
Util
Demangle.H
Please help us improve this page: Edit it on
GitHub
or
email us your edits and suggestions.
Generated by
1.8.17