Merge branch 'fixes' into main/rendor-staging
[ryzomcore.git] / ryzom / common / src / game_share / ecosystem.h
blobe55746d755b77598c9f5e95d8fc8309382e7d759
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_ECOSYSTEM_H
20 #define RY_ECOSYSTEM_H
22 #include "nel/misc/types_nl.h"
24 namespace ECOSYSTEM
26 // Please do not change the ordering of these (otherwise change arrays [ECOSYSTEM::NUM_ECOSYSTEM])
27 enum EECosystem
29 common_ecosystem = 0,
30 desert,
31 forest,
32 lacustre,
33 jungle,
34 goo,
35 primary_root,
37 unknown,
38 NUM_ECOSYSTEM = unknown
42 /**
43 * get the right ecosystem enum from the input string (case-unsensitive comparison)
44 * \param str the input string
45 * \return the EECosystem associated to this string (UNDEFINED if the string cannot be interpreted)
47 EECosystem stringToEcosystem(const std::string &str);
49 /**
50 * get the ecosystem type as a string
51 * \param cat the EECosystem cat
52 * \return the string associated to this EECosystem
54 const std::string & toString (EECosystem e);
56 }; // namespace ECOSYSTEM
59 // Currently, ecotypes are mapped to ecosystems
60 typedef ECOSYSTEM::EECosystem TEcotype;
63 #endif // RY_ECOSYSTEM_H
64 /* End of ecosystem.h */