GeoTessCPP  2.0.0
Software to facilitate storage and retrieval of 3D information about the Earth.
 All Classes Namespaces Files Functions Variables Typedefs Friends Defines
include/OptimizationType.h
Go to the documentation of this file.
00001 //- ****************************************************************************
00002 //- 
00003 //- Copyright 2009 Sandia Corporation. Under the terms of Contract
00004 //- DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government
00005 //- retains certain rights in this software.
00006 //- 
00007 //- BSD Open Source License.
00008 //- All rights reserved.
00009 //- 
00010 //- Redistribution and use in source and binary forms, with or without
00011 //- modification, are permitted provided that the following conditions are met:
00012 //- 
00013 //-    * Redistributions of source code must retain the above copyright notice,
00014 //-      this list of conditions and the following disclaimer.
00015 //-    * Redistributions in binary form must reproduce the above copyright
00016 //-      notice, this list of conditions and the following disclaimer in the
00017 //-      documentation and/or other materials provided with the distribution.
00018 //-    * Neither the name of Sandia National Laboratories nor the names of its
00019 //-      contributors may be used to endorse or promote products derived from
00020 //-      this software without specific prior written permission.
00021 //- 
00022 //- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00023 //- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00024 //- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00025 //- ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
00026 //- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00027 //- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00028 //- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00029 //- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00030 //- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00031 //- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032 //- POSSIBILITY OF SUCH DAMAGE.
00033 //-
00034 //- ****************************************************************************
00035 
00036 #ifndef OPTIMIZATIONTYPE_OBJECT_H
00037 #define OPTIMIZATIONTYPE_OBJECT_H
00038 
00039 // **** _SYSTEM INCLUDES_ ******************************************************
00040 
00041 #include <iostream>
00042 #include <string>
00043 
00044 // use standard library objects
00045 using namespace std;
00046 
00047 // **** _LOCAL INCLUDES_ *******************************************************
00048 
00049 #include "EnumType.h"
00050 
00051 // **** _BEGIN GEOTESS NAMESPACE_ **********************************************
00052 
00053 namespace geotess
00054 {
00055 
00056 // **** _FORWARD REFERENCES_ ***************************************************
00057 
00058 // **** _CLASS DEFINITION_ *****************************************************
00059 
00066 class GEOTESS_EXP_IMP OptimizationType: public EnumType
00067 {
00068 private:
00069 
00073         OptimizationType() : EnumType()
00074         {
00075         }
00076 
00080         OptimizationType(const OptimizationType& ot) : EnumType(ot)
00081         {
00082         }
00083 
00087         OptimizationType& operator=(const OptimizationType& ot)
00088         {
00089                 return *this;
00090         }
00091 
00095         static const int aSize;
00096 
00101         static inline int nextOrdinal()
00102         {
00103                 static int firstOrdinal = 0;
00104                 return firstOrdinal++;
00105         }
00106 
00112         OptimizationType(const string& name)
00113                         : EnumType(name, nextOrdinal())
00114         {
00115         }
00116 
00117 public:
00118 
00122         static const OptimizationType SPEED;
00123         static const OptimizationType MEMORY;
00124 
00128         static const OptimizationType* aArray[];
00129 
00133         virtual ~OptimizationType()
00134         {
00135         }
00136 
00137 //              /**
00138 //               * Assignment Operator.
00139 //               */
00140 //              OptimizationType& OptimizationType::operator=(const OptimizationType& ot)
00141 //              {
00142 //                      EnumType::operator=(ot);
00143 //
00144 //                      return *this;
00145 //              }
00146 
00154         static const OptimizationType* valueOf(const string& s)
00155         {
00156                 return (const OptimizationType*) EnumType::valueOf(s,
00157                                 (EnumType const* const * const ) aArray, aSize);
00158         }
00159         ;
00160 
00164         static OptimizationType const* const * const values()
00165         {
00166                 return aArray;
00167         }
00168 
00172         static int size()
00173         {
00174                 return aSize;
00175         }
00176 
00177 };
00178 // end class OptimizationType
00179 
00180 }// end namespace geotess
00181 
00182 #endif  // OPTIMIZATIONTYPE_OBJECT_H