casa  $Rev:20696$
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
AlmaRadiometerRow.h
Go to the documentation of this file.
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 */