casa
$Rev:20696$
|
00001 00002 #ifndef CCalibrationFunction_H 00003 #define CCalibrationFunction_H 00004 00005 /* 00006 * ALMA - Atacama Large Millimeter Array 00007 * (c) European Southern Observatory, 2002 00008 * (c) Associated Universities Inc., 2002 00009 * Copyright by ESO (in the framework of the ALMA collaboration), 00010 * Copyright by AUI (in the framework of the ALMA collaboration), 00011 * All rights reserved. 00012 * 00013 * This library is free software; you can redistribute it and/or 00014 * modify it under the terms of the GNU Lesser General Public 00015 * License as published by the Free software Foundation; either 00016 * version 2.1 of the License, or (at your option) any later version. 00017 * 00018 * This library is distributed in the hope that it will be useful, 00019 * but WITHOUT ANY WARRANTY, without even the implied warranty of 00020 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00021 * Lesser General Public License for more details. 00022 * 00023 * You should have received a copy of the GNU Lesser General Public 00024 * License along with this library; if not, write to the Free Software 00025 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 00026 * MA 02111-1307 USA 00027 * 00028 * ///////////////////////////////////////////////////////////////// 00029 * // WARNING! DO NOT MODIFY THIS FILE! // 00030 * // --------------------------------------------------------- // 00031 * // | This is generated code! Do not modify this file. | // 00032 * // | Any changes will be lost when the file is re-generated. | // 00033 * // --------------------------------------------------------- // 00034 * ///////////////////////////////////////////////////////////////// 00035 * 00036 * File CCalibrationFunction.h 00037 */ 00038 00039 #ifndef __cplusplus 00040 #error This is a C++ include file and cannot be used from plain C 00041 #endif 00042 00043 #include <iostream> 00044 #include <string> 00045 #include <vector> 00049 #ifndef WITHOUT_ACS 00050 #include <almaEnumerations_IFC.h> 00051 #else 00052 00053 // This part mimics the behaviour of 00054 namespace CalibrationFunctionMod 00055 { 00058 00059 const char *const revision = "1.10"; 00060 const int version = 1; 00061 00062 enum CalibrationFunction 00063 { 00064 FIRST 00065 , 00066 LAST 00067 , 00068 UNSPECIFIED 00070 }; 00071 typedef CalibrationFunction &CalibrationFunction_out; 00072 } 00073 #endif 00074 00075 namespace CalibrationFunctionMod { 00076 std::ostream & operator << ( std::ostream & out, const CalibrationFunction& value); 00077 std::istream & operator >> ( std::istream & in , CalibrationFunction& value ); 00078 } 00079 00084 class CCalibrationFunction { 00085 public: 00086 00091 static const std::string& sFIRST; 00093 static const std::string& sLAST; 00095 static const std::string& sUNSPECIFIED; 00102 static int version() ; 00103 00104 00110 static std::string revision() ; 00111 00112 00117 static unsigned int size() ; 00118 00119 00125 static std::string name(const CalibrationFunctionMod::CalibrationFunction& e); 00126 00130 static std::string toString(const CalibrationFunctionMod::CalibrationFunction& f) { return name(f); } 00131 00137 static const std::vector<std::string> names(); 00138 00139 00140 // Create a CalibrationFunction enumeration object by specifying its name. 00141 static CalibrationFunctionMod::CalibrationFunction newCalibrationFunction(const std::string& name); 00142 00148 static CalibrationFunctionMod::CalibrationFunction literal(const std::string& name); 00149 00155 static CalibrationFunctionMod::CalibrationFunction from_int(unsigned int i); 00156 00157 00158 private: 00159 /* Not Implemented. This is a pure static class. */ 00160 CCalibrationFunction(); 00161 CCalibrationFunction(const CCalibrationFunction&); 00162 CCalibrationFunction& operator=(const CCalibrationFunction&); 00163 00164 static std::string badString(const std::string& name) ; 00165 static std::string badInt(unsigned int i) ; 00166 00167 }; 00168 00169 #endif