casa
$Rev:20696$
|
00001 00002 /* 00003 * ALMA - Atacama Large Millimeter Array 00004 * (c) European Southern Observatory, 2002 00005 * (c) Associated Universities Inc., 2002 00006 * Copyright by ESO (in the framework of the ALMA collaboration), 00007 * Copyright by AUI (in the framework of the ALMA collaboration), 00008 * All rights reserved. 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free software Foundation; either 00013 * version 2.1 of the License, or (at your option) any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY, without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 00023 * MA 02111-1307 USA 00024 * 00025 * Warning! 00026 * -------------------------------------------------------------------- 00027 * | This is generated code! Do not modify this file. | 00028 * | If you do, all changes will be lost when the file is re-generated. | 00029 * -------------------------------------------------------------------- 00030 * 00031 * File AlmaRadiometerRow.h 00032 */ 00033 00034 #ifndef AlmaRadiometerRow_CLASS 00035 #define AlmaRadiometerRow_CLASS 00036 00037 #include <vector> 00038 #include <string> 00039 #include <set> 00040 00041 #ifndef WITHOUT_ACS 00042 #include <asdmIDLC.h> 00043 #endif 00044 00045 00046 00047 00048 00049 00050 00051 #include <Tag.h> 00052 00053 00054 00055 00056 00057 00058 00059 00060 00061 00062 00063 #include <ConversionException.h> 00064 #include <NoSuchRow.h> 00065 #include <IllegalAccessException.h> 00066 00067 #include <RowTransformer.h> 00068 //#include <TableStreamReader.h> 00069 00070 /*\file AlmaRadiometer.h 00071 \brief Generated from model's revision "1.61", branch "HEAD" 00072 */ 00073 00074 namespace asdm { 00075 00076 //class asdm::AlmaRadiometerTable; 00077 00078 00079 // class asdm::SpectralWindowRow; 00080 class SpectralWindowRow; 00081 00082 00083 class AlmaRadiometerRow; 00084 typedef void (AlmaRadiometerRow::*AlmaRadiometerAttributeFromBin) (EndianIStream& eis); 00085 typedef void (AlmaRadiometerRow::*AlmaRadiometerAttributeFromText) (const string& s); 00086 00093 class AlmaRadiometerRow { 00094 friend class asdm::AlmaRadiometerTable; 00095 friend class asdm::RowTransformer<AlmaRadiometerRow>; 00096 //friend class asdm::TableStreamReader<AlmaRadiometerTable, AlmaRadiometerRow>; 00097 00098 public: 00099 00100 virtual ~AlmaRadiometerRow(); 00101 00105 AlmaRadiometerTable &getTable() const; 00106 00111 bool isAdded() const; 00112 00114 // Intrinsic Table Attributes // 00116 00117 00118 // ===> Attribute almaRadiometerId 00119 00120 00121 00122 00123 00128 Tag getAlmaRadiometerId() const; 00129 00130 00131 00132 00133 00134 00135 00136 00137 00138 // ===> Attribute numAntenna, which is optional 00139 00140 00141 00146 bool isNumAntennaExists() const; 00147 00148 00149 00155 int getNumAntenna() const; 00156 00157 00158 00159 00166 void setNumAntenna (int numAntenna); 00167 00168 00169 00170 00174 void clearNumAntenna (); 00175 00176 00177 00179 // Extrinsic Table Attributes // 00181 00182 00183 // ===> Attribute spectralWindowId, which is optional 00184 00185 00186 00191 bool isSpectralWindowIdExists() const; 00192 00193 00194 00200 vector<Tag> getSpectralWindowId() const; 00201 00202 00203 00204 00211 void setSpectralWindowId (vector<Tag> spectralWindowId); 00212 00213 00214 00215 00219 void clearSpectralWindowId (); 00220 00221 00222 00224 // Links // 00226 00227 00228 00235 void setSpectralWindowId (int i, Tag spectralWindowId) ; 00236 00237 00238 00239 00240 00245 void addSpectralWindowId(Tag id); 00246 00251 void addSpectralWindowId(const vector<Tag> & id); 00252 00253 00259 const Tag getSpectralWindowId(int i); 00260 00268 SpectralWindowRow* getSpectralWindowUsingSpectralWindowId(int i); 00269 00274 vector<SpectralWindowRow *> getSpectralWindowsUsingSpectralWindowId(); 00275 00276 00277 00278 00279 00280 00281 00282 00283 00284 00293 bool equalByRequiredValue(AlmaRadiometerRow* x) ; 00294 00295 #ifndef WITHOUT_ACS 00296 00300 asdmIDL::AlmaRadiometerRowIDL *toIDL() const; 00301 #endif 00302 00303 #ifndef WITHOUT_ACS 00304 00309 void setFromIDL (asdmIDL::AlmaRadiometerRowIDL x) ; 00310 #endif 00311 00316 std::string toXML() const; 00317 00324 void setFromXML (std::string rowDoc) ; 00325 00328 // binary-deserialization material from an EndianIStream // 00330 00331 std::map<std::string, AlmaRadiometerAttributeFromBin> fromBinMethods; 00332 void almaRadiometerIdFromBin( EndianIStream& eis); 00333 00334 void numAntennaFromBin( EndianIStream& eis); 00335 void spectralWindowIdFromBin( EndianIStream& eis); 00336 00337 00345 static AlmaRadiometerRow* fromBin(EndianIStream& eis, AlmaRadiometerTable& table, const std::vector<std::string>& attributesSeq); 00347 00348 private: 00352 AlmaRadiometerTable &table; 00356 bool hasBeenAdded; 00357 00358 // This method is used by the Table class when this row is added to the table. 00359 void isAdded(bool added); 00360 00361 00370 AlmaRadiometerRow (AlmaRadiometerTable &table); 00371 00389 AlmaRadiometerRow (AlmaRadiometerTable &table, AlmaRadiometerRow &row); 00390 00392 // Intrinsic Table Attributes // 00394 00395 00396 // ===> Attribute almaRadiometerId 00397 00398 00399 00400 Tag almaRadiometerId; 00401 00402 00403 00404 00414 void setAlmaRadiometerId (Tag almaRadiometerId); 00415 00416 00417 00418 00419 // ===> Attribute numAntenna, which is optional 00420 00421 00422 bool numAntennaExists; 00423 00424 00425 int numAntenna; 00426 00427 00428 00429 00430 00432 // Extrinsic Table Attributes // 00434 00435 00436 // ===> Attribute spectralWindowId, which is optional 00437 00438 00439 bool spectralWindowIdExists; 00440 00441 00442 vector<Tag> spectralWindowId; 00443 00444 00445 00446 00447 00449 // Links // 00451 00452 00453 00454 00455 00456 00457 00458 00459 /* 00461 // binary-deserialization material from an EndianIStream // 00463 std::map<std::string, AlmaRadiometerAttributeFromBin> fromBinMethods; 00464 void almaRadiometerIdFromBin( EndianIStream& eis); 00465 00466 void numAntennaFromBin( EndianIStream& eis); 00467 void spectralWindowIdFromBin( EndianIStream& eis); 00468 00469 */ 00470 00472 // text-deserialization material // 00474 std::map<std::string, AlmaRadiometerAttributeFromText> fromTextMethods; 00475 00476 void almaRadiometerIdFromText (const string & s); 00477 00478 00479 00480 void numAntennaFromText (const string & s); 00481 00482 00483 void spectralWindowIdFromText (const string & s); 00484 00485 00486 00487 void fromText(const std::string& attributeName, const std::string& t); 00488 00493 void toBin(EndianOSStream& eoss); 00494 00504 }; 00505 00506 } // End namespace asdm 00507 00508 #endif /* AlmaRadiometer_CLASS */