Merge branch 'fixes' into main/rendor-staging
[ryzomcore.git] / ryzom / common / src / game_share / enum_template.h
blob1cb747b83cb12c6b6ee3443d8626fd0601249736
1 // Ryzom - MMORPG Framework <http://dev.ryzom.com/projects/ryzom/>
2 // Copyright (C) 2010 Winch Gate Property Limited
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU Affero General Public License as
6 // published by the Free Software Foundation, either version 3 of the
7 // License, or (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU Affero General Public License for more details.
14 // You should have received a copy of the GNU Affero General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #ifndef RY_ENUM_ROLES_H
20 #define RY_ENUM_ROLES_H
22 #include "nel/misc/types_nl.h"
24 namespace ROLES
26 enum EEnumRole
28 melee_warrior = 0,
29 range_warrior,
30 attack_magician,
31 buffer_magician,
32 healer_magician,
33 harvester,
34 shopkeeper,
35 faber,
36 all_caster,
37 all,
39 UNKNOWN = 0,
41 NUM_ENUM_ROLE
45 /**
46 * get the right EEnumTemplate enum from the input string
47 * \param str the input string
48 * \return the EEnumTemplate associated to this string (UNKNOWN if the string cannot be interpreted)
50 EEnumTemplate stringToEnum(const std::string &str);
52 /**
53 * get the EEnumTemplate type as a string
54 * \param e the EEnumTemplate enum
55 * \return the string associated to this EEnumTemplate
57 const std::string & enumToString (EEnumTemplate e);
59 }; // namespace ENUM_ROLES
61 #endif // RY_ENUM_ROLES_H