Main MRPT website
>
C++ reference
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
mrpt
utils
TEnumType.h
Go to the documentation of this file.
1
/* +---------------------------------------------------------------------------+
2
| The Mobile Robot Programming Toolkit (MRPT) C++ library |
3
| |
4
| http://www.mrpt.org/ |
5
| |
6
| Copyright (C) 2005-2012 University of Malaga |
7
| |
8
| This software was written by the Machine Perception and Intelligent |
9
| Robotics Lab, University of Malaga (Spain). |
10
| Contact: Jose-Luis Blanco <jlblanco@ctima.uma.es> |
11
| |
12
| This file is part of the MRPT project. |
13
| |
14
| MRPT is free software: you can redistribute it and/or modify |
15
| it under the terms of the GNU General Public License as published by |
16
| the Free Software Foundation, either version 3 of the License, or |
17
| (at your option) any later version. |
18
| |
19
| MRPT is distributed in the hope that it will be useful, |
20
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
21
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
22
| GNU General Public License for more details. |
23
| |
24
| You should have received a copy of the GNU General Public License |
25
| along with MRPT. If not, see <http://www.gnu.org/licenses/>. |
26
| |
27
+---------------------------------------------------------------------------+ */
28
#ifndef mrpt_TEnumType_H
29
#define mrpt_TEnumType_H
30
31
#include <
mrpt/utils/utils_defs.h
>
32
#include <
mrpt/utils/stl_extensions.h
>
33
34
namespace
mrpt
35
{
36
namespace
utils
37
{
38
/** Only specializations of this class are defined for each enum type of interest
39
* \sa TEnumType \ingroup mrpt_base_grp
40
*/
41
template
<
typename
ENUMTYPE>
42
struct
TEnumTypeFiller
43
{
44
typedef
ENUMTYPE
enum_t
;
45
static
void
fill
(
bimap<enum_t,std::string>
&m_map);
46
};
47
48
49
/** A helper class that can convert an enum value into its textual representation, and viceversa. \ingroup mrpt_base_grp */
50
template
<
typename
ENUMTYPE>
51
struct
TEnumType
52
{
53
/** Gives the numerical name for a given enum text name \exception std::exception on unknown enum name */
54
static
ENUMTYPE
name2value
(
const
std::string &name)
55
{
56
if
(
getBimap
().
empty
())
TEnumTypeFiller<ENUMTYPE>::fill
(
getBimap
());
57
return
getBimap
().inverse(name);
58
}
59
60
/** Gives the textual name for a given enum value \exception std::exception on unknown enum value name */
61
static
std::string
value2name
(
const
ENUMTYPE val)
62
{
63
if
(
getBimap
().
empty
())
TEnumTypeFiller<ENUMTYPE>::fill
(
getBimap
());
64
return
getBimap
().direct(val);
65
}
66
67
/** Singleton access */
68
static
inline
bimap<ENUMTYPE,std::string>
&
getBimap
()
69
{
70
static
bimap<ENUMTYPE,std::string>
data;
71
return
data;
72
}
73
};
74
75
}
// End of namespace
76
}
// end of namespace
77
#endif
Page generated by
Doxygen 1.8.3
for MRPT 0.9.6 SVN: at Fri Feb 15 22:05:02 EST 2013