00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034 #ifndef PolarizationTable_CLASS
00035 #define PolarizationTable_CLASS
00036
00037 #include <string>
00038 #include <vector>
00039 #include <map>
00040 #include <set>
00041 using std::string;
00042 using std::vector;
00043 using std::map;
00044
00045 #include <Angle.h>
00046 #include <AngularRate.h>
00047 #include <ArrayTime.h>
00048 #include <ArrayTimeInterval.h>
00049 #include <Complex.h>
00050 #include <Entity.h>
00051 #include <EntityId.h>
00052 #include <EntityRef.h>
00053 #include <Flux.h>
00054 #include <Frequency.h>
00055 #include <Humidity.h>
00056 #include <Interval.h>
00057 #include <Length.h>
00058 #include <PartId.h>
00059 #include <Pressure.h>
00060 #include <Speed.h>
00061 #include <Tag.h>
00062 #include <Temperature.h>
00063 #include <ConversionException.h>
00064 #include <DuplicateKey.h>
00065 #include <UniquenessViolationException.h>
00066 #include <NoSuchRow.h>
00067 #include <DuplicateKey.h>
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082 #include "CStokesParameter.h"
00083 using namespace StokesParameterMod;
00084
00085
00086
00087 #include "CPolarizationType.h"
00088 using namespace PolarizationTypeMod;
00089
00090
00091
00092
00093
00094 #ifndef WITHOUT_ACS
00095 #include <asdmIDLC.h>
00096 using asdmIDL::PolarizationTableIDL;
00097 #endif
00098
00099 using asdm::Angle;
00100 using asdm::AngularRate;
00101 using asdm::ArrayTime;
00102 using asdm::Complex;
00103 using asdm::Entity;
00104 using asdm::EntityId;
00105 using asdm::EntityRef;
00106 using asdm::Flux;
00107 using asdm::Frequency;
00108 using asdm::Humidity;
00109 using asdm::Interval;
00110 using asdm::Length;
00111 using asdm::PartId;
00112 using asdm::Pressure;
00113 using asdm::Speed;
00114 using asdm::Tag;
00115 using asdm::Temperature;
00116
00117 using asdm::DuplicateKey;
00118 using asdm::ConversionException;
00119 using asdm::NoSuchRow;
00120 using asdm::DuplicateKey;
00121
00122 #include <Representable.h>
00123
00124 namespace asdm {
00125
00126
00127
00128
00129 class ASDM;
00130 class PolarizationRow;
00185 class PolarizationTable : public Representable {
00186 friend class asdm::ASDM;
00187
00188 public:
00189
00190
00196 static vector<string> getKeyName();
00197
00198
00199 virtual ~PolarizationTable();
00200
00206 ASDM &getContainer() const;
00207
00213 unsigned int size() ;
00214
00220 string getName() const;
00221
00225 Entity getEntity() const;
00226
00231 void setEntity(Entity e);
00232
00233
00234
00235
00236
00241 PolarizationRow *newRow();
00242
00247 PolarizationRow* newRowEmpty();
00248
00249
00261 PolarizationRow *newRow(int numCorr, vector<StokesParameter > corrType, vector<vector<PolarizationType > > corrProduct);
00262
00267 PolarizationRow *newRowFull(int numCorr, vector<StokesParameter > corrType, vector<vector<PolarizationType > > corrProduct);
00268
00269
00282 PolarizationRow *newRow(PolarizationRow *row);
00283
00288 PolarizationRow *newRowCopy(PolarizationRow *row);
00289
00290
00291
00292
00293
00294
00295
00296
00306 PolarizationRow* add(PolarizationRow* x) ;
00307
00308
00309
00310
00311
00312
00313
00319 vector<PolarizationRow *> get() ;
00320
00321
00322
00323
00324
00334 PolarizationRow* PolarizationTable::getRowByKey(Tag polarizationId);
00335
00336
00337
00338
00339
00353 PolarizationRow* lookup(int numCorr, vector<StokesParameter > corrType, vector<vector<PolarizationType > > corrProduct);
00354
00355
00356 #ifndef WITHOUT_ACS
00357
00363 PolarizationTableIDL *toIDL() ;
00364 #endif
00365
00366 #ifndef WITHOUT_ACS
00367
00373 void fromIDL(PolarizationTableIDL x) throw(DuplicateKey,ConversionException);
00374 #endif
00375
00379 char *toFITS() const throw(ConversionException);
00380
00384 void fromFITS(char *fits) throw(ConversionException);
00385
00389 string toVOTable() const throw(ConversionException);
00390
00394 void fromVOTable(string vo) throw(ConversionException);
00395
00402 string toXML() throw(ConversionException);
00403
00409 void fromXML(string xmlDoc) throw(ConversionException);
00410
00416 string toMIME();
00417
00424 void setFromMIME(const string & mimeMsg);
00425
00435 void toFile(string directory);
00436
00445 void setFromFile(const string& directory);
00446
00447 private:
00448
00457 PolarizationTable (ASDM & container);
00458
00459 ASDM & container;
00460
00461 bool archiveAsBin;
00462 bool fileAsBin ;
00463
00464 Entity entity;
00465
00466
00467
00468 map<string,int> noAutoIncIds;
00469 void autoIncrement(string key, PolarizationRow* x);
00470
00471
00475 static string tableName;
00476
00477
00481 static vector<string> key;
00482
00483
00489 PolarizationRow* checkAndAdd(PolarizationRow* x) throw (DuplicateKey, UniquenessViolationException);
00490
00491
00492
00493
00494
00495
00496 vector<PolarizationRow * > privateRows;
00497
00498
00499
00500 vector<PolarizationRow *> row;
00501
00502
00503 void error() throw(ConversionException);
00504
00505 };
00506
00507 }
00508
00509 #endif