llenum.h
上传用户:king477883
上传日期:2021-03-01
资源大小:9553k
文件大小:2k
源码类别:

游戏引擎

开发平台:

C++ Builder

  1. /** 
  2.  * @file llenum.h
  3.  * @author Tom Yedwab
  4.  * @brief Utility class for storing enum value <-> string lookup.
  5.  *
  6.  * $LicenseInfo:firstyear=2006&license=viewergpl$
  7.  * 
  8.  * Copyright (c) 2006-2010, Linden Research, Inc.
  9.  * 
  10.  * Second Life Viewer Source Code
  11.  * The source code in this file ("Source Code") is provided by Linden Lab
  12.  * to you under the terms of the GNU General Public License, version 2.0
  13.  * ("GPL"), unless you have obtained a separate licensing agreement
  14.  * ("Other License"), formally executed by you and Linden Lab.  Terms of
  15.  * the GPL can be found in doc/GPL-license.txt in this distribution, or
  16.  * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
  17.  * 
  18.  * There are special exceptions to the terms and conditions of the GPL as
  19.  * it is applied to this Source Code. View the full text of the exception
  20.  * in the file doc/FLOSS-exception.txt in this software distribution, or
  21.  * online at
  22.  * http://secondlifegrid.net/programs/open_source/licensing/flossexception
  23.  * 
  24.  * By copying, modifying or distributing this software, you acknowledge
  25.  * that you have read and understood your obligations described above,
  26.  * and agree to abide by those obligations.
  27.  * 
  28.  * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
  29.  * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
  30.  * COMPLETENESS OR PERFORMANCE.
  31.  * $/LicenseInfo$
  32.  */
  33. #ifndef LL_LLENUM_H
  34. #define LL_LLENUM_H
  35. class LLEnum
  36. {
  37. public:
  38. typedef std::pair<const std::string, const U32> enum_t;
  39. enum
  40. {
  41. UNDEFINED = 0xffffffff,
  42. };
  43. LLEnum(const enum_t values_array[], const U32 length)
  44. {
  45. for (U32 i=0; i<length; ++i)
  46. {
  47. mEnumMap.insert(values_array[i]);
  48. if (values_array[i].second >= mEnumArray.size())
  49. {
  50. mEnumArray.resize(values_array[i].second+1);
  51. }
  52. mEnumArray[values_array[i].second] = values_array[i].first;
  53. }
  54. }
  55. U32 operator[](std::string str)
  56. {
  57. std::map<const std::string, const U32>::iterator itor;
  58. itor = mEnumMap.find(str);
  59. if (itor != mEnumMap.end())
  60. {
  61. return itor->second;
  62. }
  63. return UNDEFINED;
  64. }
  65. const std::string operator[](U32 index)
  66. {
  67. if (index < mEnumArray.size())
  68. {
  69. return mEnumArray[index];
  70. }
  71. return "";
  72. }
  73. private:
  74. std::map<const std::string, const U32> mEnumMap;
  75. std::vector<std::string> mEnumArray;
  76. };
  77. #endif // LL_LLENUM_H