casa  $Rev:20696$
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
SquareLawDetectorRow.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 SquareLawDetectorRow.h
00032  */
00033  
00034 #ifndef SquareLawDetectorRow_CLASS
00035 #define SquareLawDetectorRow_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 #include "CDetectorBandType.h"
00063         
00064 
00065 
00066 
00067 #include <ConversionException.h>
00068 #include <NoSuchRow.h>
00069 #include <IllegalAccessException.h>
00070 
00071 #include <RowTransformer.h>
00072 //#include <TableStreamReader.h>
00073 
00074 /*\file SquareLawDetector.h
00075     \brief Generated from model's revision "1.61", branch "HEAD"
00076 */
00077 
00078 namespace asdm {
00079 
00080 //class asdm::SquareLawDetectorTable;
00081 
00082         
00083 
00084 class SquareLawDetectorRow;
00085 typedef void (SquareLawDetectorRow::*SquareLawDetectorAttributeFromBin) (EndianIStream& eis);
00086 typedef void (SquareLawDetectorRow::*SquareLawDetectorAttributeFromText) (const string& s);
00087 
00094 class SquareLawDetectorRow {
00095 friend class asdm::SquareLawDetectorTable;
00096 friend class asdm::RowTransformer<SquareLawDetectorRow>;
00097 //friend class asdm::TableStreamReader<SquareLawDetectorTable, SquareLawDetectorRow>;
00098 
00099 public:
00100 
00101         virtual ~SquareLawDetectorRow();
00102 
00106         SquareLawDetectorTable &getTable() const;
00107         
00112         bool isAdded() const;
00113                 
00115         // Intrinsic Table Attributes //
00117         
00118         
00119         // ===> Attribute squareLawDetectorId
00120         
00121         
00122         
00123 
00124         
00129         Tag getSquareLawDetectorId() const;
00130         
00131  
00132         
00133         
00134         
00135         
00136 
00137 
00138         
00139         // ===> Attribute numBand
00140         
00141         
00142         
00143 
00144         
00149         int getNumBand() const;
00150         
00151  
00152         
00153         
00161         void setNumBand (int numBand);
00162                 
00163         
00164         
00165         
00166 
00167 
00168         
00169         // ===> Attribute bandType
00170         
00171         
00172         
00173 
00174         
00179         DetectorBandTypeMod::DetectorBandType getBandType() const;
00180         
00181  
00182         
00183         
00191         void setBandType (DetectorBandTypeMod::DetectorBandType bandType);
00192                 
00193         
00194         
00195         
00196 
00197 
00199         // Extrinsic Table Attributes //
00201         
00203         // Links //
00205         
00206         
00207         
00208         
00218         bool compareNoAutoInc(int numBand, DetectorBandTypeMod::DetectorBandType bandType);
00219         
00220         
00221 
00222         
00232         bool compareRequiredValue(int numBand, DetectorBandTypeMod::DetectorBandType bandType); 
00233                  
00234         
00243         bool equalByRequiredValue(SquareLawDetectorRow* x) ;
00244         
00245 #ifndef WITHOUT_ACS
00246 
00250         asdmIDL::SquareLawDetectorRowIDL *toIDL() const;
00251 #endif
00252         
00253 #ifndef WITHOUT_ACS
00254 
00259         void setFromIDL (asdmIDL::SquareLawDetectorRowIDL x) ;
00260 #endif
00261         
00266         std::string toXML() const;
00267 
00274         void setFromXML (std::string rowDoc) ;
00275 
00278         // binary-deserialization material from an EndianIStream  //
00280 
00281         std::map<std::string, SquareLawDetectorAttributeFromBin> fromBinMethods;
00282 void squareLawDetectorIdFromBin( EndianIStream& eis);
00283 void numBandFromBin( EndianIStream& eis);
00284 void bandTypeFromBin( EndianIStream& eis);
00285 
00286         
00287 
00295          static SquareLawDetectorRow* fromBin(EndianIStream& eis, SquareLawDetectorTable& table, const std::vector<std::string>& attributesSeq);         
00297 
00298 private:
00302         SquareLawDetectorTable &table;
00306         bool hasBeenAdded;
00307 
00308         // This method is used by the Table class when this row is added to the table.
00309         void isAdded(bool added);
00310 
00311 
00320         SquareLawDetectorRow (SquareLawDetectorTable &table);
00321 
00339          SquareLawDetectorRow (SquareLawDetectorTable &table, SquareLawDetectorRow &row);
00340                 
00342         // Intrinsic Table Attributes //
00344         
00345         
00346         // ===> Attribute squareLawDetectorId
00347         
00348         
00349 
00350         Tag squareLawDetectorId;
00351 
00352         
00353         
00354         
00364         void setSquareLawDetectorId (Tag squareLawDetectorId);
00365                 
00366         
00367 
00368         
00369         // ===> Attribute numBand
00370         
00371         
00372 
00373         int numBand;
00374 
00375         
00376         
00377         
00378 
00379         
00380         // ===> Attribute bandType
00381         
00382         
00383 
00384         DetectorBandTypeMod::DetectorBandType bandType;
00385 
00386         
00387         
00388         
00389 
00391         // Extrinsic Table Attributes //
00393         
00395         // Links //
00397         
00398         
00399 /*
00401         // binary-deserialization material from an EndianIStream  //
00403         std::map<std::string, SquareLawDetectorAttributeFromBin> fromBinMethods;
00404 void squareLawDetectorIdFromBin( EndianIStream& eis);
00405 void numBandFromBin( EndianIStream& eis);
00406 void bandTypeFromBin( EndianIStream& eis);
00407 
00408         
00409 */
00410         
00412         // text-deserialization material //
00414         std::map<std::string, SquareLawDetectorAttributeFromText> fromTextMethods;
00415         
00416 void squareLawDetectorIdFromText (const string & s);
00417         
00418         
00419 void numBandFromText (const string & s);
00420         
00421         
00422 void bandTypeFromText (const string & s);
00423         
00424 
00425                 
00426         
00427         void fromText(const std::string& attributeName, const std::string&  t);
00428         
00433          void toBin(EndianOSStream& eoss);
00434                  
00444 };
00445 
00446 } // End namespace asdm
00447 
00448 #endif /* SquareLawDetector_CLASS */