Changeset 1499 in Sophya for trunk/SophyaExt/FitsIOServer/fitsxntuple.cc
- Timestamp:
- May 17, 2001, 6:26:45 PM (24 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/SophyaExt/FitsIOServer/fitsxntuple.cc
r1371 r1499 90 90 else if (ss == FitsFile::FitsDataType_float) FfitsCol.push_back(k); 91 91 else if (ss == FitsFile::FitsDataType_int) IfitsCol.push_back(k); 92 else if (ss == FitsFile::FitsDataType_long) IfitsCol.push_back(k); 93 else if (ss == FitsFile::FitsDataType_byte) IfitsCol.push_back(k); 92 94 else if (ss == FitsFile::FitsDataType_char) SfitsCol.push_back(k); 93 95 else { … … 122 124 ColName[compt++][LONNOM] = '\0'; 123 125 } 124 126 int ND = DfitsCol.size(); 127 int NF = FfitsCol.size(); 128 int NI = IfitsCol.size(); 129 int NS = SfitsCol.size(); 125 130 if(dobj_ == NULL) 126 131 { 127 dobj_= new XNTuple( DfitsCol.size(), FfitsCol.size(), IfitsCol.size(), SfitsCol.size(),ColName);132 dobj_= new XNTuple(ND, NF, NI, NS,ColName); 128 133 ownobj_ = true; 129 134 } … … 132 137 if (ownobj_) 133 138 { 134 (*dobj_)= XNTuple( DfitsCol.size(), FfitsCol.size(), IfitsCol.size(), SfitsCol.size(),ColName);139 (*dobj_)= XNTuple(ND, NF, NI, NS,ColName); 135 140 } 136 141 else 137 142 { 138 if ( DfitsCol.size() != dobj_->NDVar() || FfitsCol.size() != dobj_->NFVar() || IfitsCol.size() != dobj_->NIVar() || SfitsCol.size()!= dobj_->NSVar())143 if (ND != dobj_->NDVar() || NF != dobj_->NFVar() || NI != dobj_->NIVar() || NS != dobj_->NSVar()) 139 144 { 140 145 cout << " WARNING : FITS_XNTuple : XNTuple reconfigured " << endl; 141 (*dobj_)= XNTuple( DfitsCol.size(), FfitsCol.size(), IfitsCol.size(), SfitsCol.size(),ColName);146 (*dobj_)= XNTuple(ND, NF, NI, NS,ColName); 142 147 } 143 148 } … … 155 160 char** cligne; 156 161 157 if ( DfitsCol.size()>0) dligne = new double[DfitsCol.size()];162 if (ND>0) dligne = new double[ND]; 158 163 else dligne=NULL; 159 if ( FfitsCol.size()>0) fligne = new float[FfitsCol.size()];164 if (NF>0) fligne = new float[NF]; 160 165 else fligne=NULL; 161 if ( IfitsCol.size()>0) iligne = new int[IfitsCol.size()];166 if (NI) iligne = new int[NI]; 162 167 else iligne=NULL; 163 if ( SfitsCol.size()>0)164 { 165 cligne = new char*[ SfitsCol.size()];168 if (NS) 169 { 170 cligne = new char*[NS]; 166 171 int taille_des_chaines=0; 167 for (k=0; k< SfitsCol.size(); k++) taille_des_chaines = max( taille_des_chaines, is.ColStringLengthFromFits(SfitsCol[k]) );168 for (k=0; k< SfitsCol.size(); k++) cligne[k]=new char[taille_des_chaines+1];172 for (k=0; k< NS; k++) taille_des_chaines = max( taille_des_chaines, is.ColStringLengthFromFits(SfitsCol[k]) ); 173 for (k=0; k<NS; k++) cligne[k]=new char[taille_des_chaines+1]; 169 174 } 170 175 else cligne=NULL; … … 196 201 void FITS_XNTuple::WriteToFits(FitsOutFile& os) 197 202 { 203 198 204 if(dobj_ == NULL) 199 205 { … … 206 212 // table will have 'nrows' rows 207 213 int nrows = dobj_->NEntry(); 214 cout << " FITS_XNTuple::WriteToFits : nombre de lignes a ecrire " << nrows << endl; 208 215 // get names and values from the join DVList object 209 216 DVList dvl= dobj_->Info();
Note:
See TracChangeset
for help on using the changeset viewer.