casa  $Rev:20696$
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.62", 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);       
00346  
00353          void fromText(const std::string& attributeName, const std::string&  t);
00355 
00356 private:
00360         AlmaRadiometerTable &table;
00364         bool hasBeenAdded;
00365 
00366         // This method is used by the Table class when this row is added to the table.
00367         void isAdded(bool added);
00368 
00369 
00378         AlmaRadiometerRow (AlmaRadiometerTable &table);
00379 
00397          AlmaRadiometerRow (AlmaRadiometerTable &table, AlmaRadiometerRow &row);
00398                 
00400         // Intrinsic Table Attributes //
00402         
00403         
00404         // ===> Attribute almaRadiometerId
00405         
00406         
00407 
00408         Tag almaRadiometerId;
00409 
00410         
00411         
00412         
00422         void setAlmaRadiometerId (Tag almaRadiometerId);
00423                 
00424         
00425 
00426         
00427         // ===> Attribute numAntenna, which is optional
00428         
00429         
00430         bool numAntennaExists;
00431         
00432 
00433         int numAntenna;
00434 
00435         
00436         
00437         
00438 
00440         // Extrinsic Table Attributes //
00442         
00443         
00444         // ===> Attribute spectralWindowId, which is optional
00445         
00446         
00447         bool spectralWindowIdExists;
00448         
00449 
00450         vector<Tag>  spectralWindowId;
00451 
00452         
00453         
00454         
00455 
00457         // Links //
00459         
00460         
00461                 
00462 
00463 
00464         
00465 
00466         
00467 /*
00469         // binary-deserialization material from an EndianIStream  //
00471         std::map<std::string, AlmaRadiometerAttributeFromBin> fromBinMethods;
00472 void almaRadiometerIdFromBin( EndianIStream& eis);
00473 
00474 void numAntennaFromBin( EndianIStream& eis);
00475 void spectralWindowIdFromBin( EndianIStream& eis);
00476 
00477 */
00478         
00480         // text-deserialization material //
00482         std::map<std::string, AlmaRadiometerAttributeFromText> fromTextMethods;
00483         
00484 void almaRadiometerIdFromText (const string & s);
00485         
00486 
00487         
00488 void numAntennaFromText (const string & s);
00489         
00490         
00491 void spectralWindowIdFromText (const string & s);
00492         
00493         
00494         
00499          void toBin(EndianOSStream& eoss);
00500                  
00510 };
00511 
00512 } // End namespace asdm
00513 
00514 #endif /* AlmaRadiometer_CLASS */
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines