2018-05-24 13:47:48 +02:00

205 lines
4.4 KiB
C++

#include "fileIO.h"
using namespace std;
/* I/O */
/* generates file name without extension*/
string fileIO::createFileName() {
pthread_mutex_lock(&mf);
currentFileName=fileIOStatic::createFileName(filePath, \
fileName, \
getActionMask(), \
getCurrentScanVariable(0), \
getScanPrecision(0), \
getCurrentScanVariable(1), \
getScanPrecision(1), \
getCurrentPositionIndex(), \
getNumberOfPositions(), \
*fileIndex, \
frameIndex, \
detIndex \
);
//if (getDetectorsType()==JUNGFRAUCTB) {
// nBytes=2*getTotalNumberOfChannels();
//} else
nBytes=getDataBytes();
pthread_mutex_unlock(&mf);
return currentFileName;
}
/* generates file prefix for receivers */
string fileIO::createReceiverFilePrefix() {
pthread_mutex_lock(&mf);
currentReceiverFilePrefix=fileIOStatic::createReceiverFilePrefix(fileName, \
getActionMask(), \
getCurrentScanVariable(0), \
getScanPrecision(0), \
getCurrentScanVariable(1), \
getScanPrecision(1), \
getCurrentPositionIndex(), \
getNumberOfPositions(), \
detIndex \
);
pthread_mutex_unlock(&mf);
return currentReceiverFilePrefix;
}
/*writes raw data file */
int fileIO::writeDataFile(string fname, double *data, double *err, double *ang, char dataformat, int nch){
if (nch==-1)
nch=getTotalNumberOfChannels();
// cout << "Write filexxx...." << endl;
return fileIOStatic::writeDataFile(fname, nch, data, err, ang, dataformat);
}
int fileIO::writeDataFile(ofstream &outfile, double *data, double *err, double *ang, char dataformat, int nch, int offset){
if (nch==-1)
nch=getTotalNumberOfChannels();
//cout << "Write file...." << endl;
return fileIOStatic::writeDataFile(outfile, nch, data, err, ang, dataformat, offset);
}
int fileIO::writeDataFile(string fname, int *data){
return fileIOStatic::writeDataFile(fname, getTotalNumberOfChannels(), data);
}
int fileIO::writeDataFile(ofstream &outfile, int *data, int offset){
// cout << "Write raw file...." << endl;
return fileIOStatic::writeDataFile(outfile, getTotalNumberOfChannels(), data, offset);
}
int fileIO::writeDataFile(void *data, int iframe) {
if (iframe<0)
iframe=frameIndex;
if ((*framesPerFile)<2)
iframe=-1;
if ((iframe%(*framesPerFile))==0 || (iframe<0) || filefd==0) {
createFileName();
filefd = fopen((currentFileName+string(".raw")).c_str(), "w");
}
if (filefd){
// fileIOStatic::writeBinaryDataFile(filefd,getDataBytes(), data);
cout <<"Writing "<< nBytes<< " dataBytes"<< endl;
fileIOStatic::writeBinaryDataFile(filefd,nBytes, data);
iframe++;
}
if ((iframe%(*framesPerFile)==0) || (iframe<0)) {
if (filefd)
fclose(filefd);
filefd=NULL;
}
return 0;
}
int fileIO::closeDataFile() {
cout << "close file...." << endl;
if (filefd)
fclose(filefd);
filefd=NULL;
return 0;
}
int fileIO::writeDataFile(string fname, short int *data){
cout << "Write raw file...." << endl;
return fileIOStatic::writeDataFile(fname, getTotalNumberOfChannels(), data);
}
int fileIO::writeDataFile(ofstream &outfile, short int *data, int offset){
return fileIOStatic::writeDataFile(outfile, getTotalNumberOfChannels(), data, offset);
}
int fileIO::readDataFile(string fname, double *data, double *err, double *ang, char dataformat) {
return fileIOStatic::readDataFile(getTotalNumberOfChannels(), fname, data, err, ang, dataformat);
}
int fileIO::readDataFile(ifstream &infile, double *data, double *err, double *ang, char dataformat, int offset) {
return fileIOStatic::readDataFile(getTotalNumberOfChannels(), infile, data, err, ang, dataformat, offset);
}
int fileIO::readDataFile(string fname, int *data){
return fileIOStatic::readDataFile(fname, data, getTotalNumberOfChannels());
};
int fileIO::readDataFile(ifstream &infile, int *data, int offset){
return fileIOStatic::readDataFile(infile, data, getTotalNumberOfChannels(), offset);
};
int fileIO::readDataFile(string fname, short int *data){
return fileIOStatic::readDataFile(fname, data, getTotalNumberOfChannels());
};
int fileIO::readDataFile(ifstream &infile, short int *data, int offset){
return fileIOStatic::readDataFile(infile, data, getTotalNumberOfChannels(),offset);
};