/* * FileReaderCDF.hh * * Created on: Nov 24, 2014 * Author: AKKA */ #ifndef FILEREADERCDF_HH_ #define FILEREADERCDF_HH_ #include #include "SpeasyProxyParamData.hh" #include "cdf.h" namespace AMDA { namespace SpeasyProxyInterface { /* * @brief Status for getParamPacketData function */ typedef enum { //more data is needed (ie. the paket is full and must be proceed before to continue) FRS_MORE, //end of file FRS_EOF, //stop time is reached FRS_FINISH, //error detected FRS_ERROR } FileReaderStatus; /* * @brief Implementation of the class FileReaderAbstract to load a CDF file format */ class FileReaderCDF { public: /* * @brief Constructor */ FileReaderCDF(); /* * @brief Destructor */ ~FileReaderCDF(); /* * @brief Open a CDF file */ bool open(std::string filePath); /* * @brief Close the CDF file */ bool close(void); /* * @brief Test if a CDF file is currently opened */ bool isOpened(void); /* * @brief Get the id of the time param to use. For the CDF format, it's the first CDF_EPOCH var */ std::string getTimeParamId(void); /* * @brief Get a param type and a param size in the CDF file */ bool getParamInfo(std::string& paramId, SpeasyProxyParamType& paramType, int& dim1Size, int& dim2Size); /* * @brief Get the index of the nearest record of time (the higher one) in the CDF file */ int getRecordIndex(std::string& timeId, double time); /* * @brief Get a param packet from the CDF file */ FileReaderStatus getParamPacketData(std::string& timeId, std::string& paramId, SpeasyProxyParamDataPacket *packet); /* * @brief Get an information */ bool getInfo(const char* pInfoName, std::vector& res); protected: /* * @brief TimeStamp (Unix time) to EPOCH time conversion */ double timeStampToEPOCHTime(double timeStamp); /* * @brief EPOCH time to TimeStamp conversion */ double epochTimeToTimeStamp(double epochTime); /* * @brief EPOCH16 time to EPOCH conversion */ double epoch16ToEpochTime(double epoch16Time[]); /* * @brief TT2000 time to EPOCH conversion */ double tt2000ToEpochTime(long long tt2000Time); private: /* * @brief CDF var type : rVariable or zVariable */ typedef enum {CDFVT_R,CDFVT_Z} CDFVarType; /* * @brief Working structure to contain CDF variable info */ typedef struct { //variable name char _name[CDF_VAR_NAME_LEN256+1]; //rVariable or zVariable CDFVarType _type; //variable number long _num; //data type long _dataType; //number of bytes for the data type long _numBytes; //number of elements (of the data type) long _numElts; //number of dimensions long _numDims; //dimension sizes long _dimSizes[CDF_MAX_DIMS]; //record variance long _recVary; //dimension variances long _dimVarys[CDF_MAX_DIMS]; //maximum record number long _maxRecNum; } CDFVarInfo; /* * @brief Working buffers container */ class CDFWorkingBuffers { public: /* * @brief Buffer type: */ typedef enum { //buffer used to store time data BUFFER_TIME, //buffer used to store param data BUFFER_DATA, //buffer used to store packet data for one record BUFFER_PACKETREC } BufferType; /* * @brief Constructor */ CDFWorkingBuffers() : _timeBuffer(NULL), _dataBuffer(NULL), _packetRecBuffer(NULL) { } /* * @brief Destructor */ ~CDFWorkingBuffers() { //free all buffers if (_timeBuffer != NULL) free(_timeBuffer); if (_dataBuffer != NULL) free(_dataBuffer); if (_packetRecBuffer != NULL) free(_packetRecBuffer); } /* * @brief Get buffer pointer from a buffer type */ void* getBuffer(BufferType type) { switch (type) { case BUFFER_TIME: return _timeBuffer; case BUFFER_DATA: return _dataBuffer; case BUFFER_PACKETREC: return _packetRecBuffer; } return NULL; } /* * @brief Reallocate a buffer from a buffer type */ void reallocBuffer(BufferType type, long size) { switch (type) { case BUFFER_TIME: if (_timeBuffer != NULL) free(_timeBuffer); _timeBuffer = malloc(size); break; case BUFFER_DATA: if (_dataBuffer != NULL) free(_dataBuffer); _dataBuffer = malloc(size); break; case BUFFER_PACKETREC: if (_packetRecBuffer != NULL) free(_packetRecBuffer); _packetRecBuffer = malloc(size); break; } } private: /* * @brief Buffer for time data */ void* _timeBuffer; /* * @brief Buffer for param data */ void* _dataBuffer; /* * @brief Buffer for one record packet data */ void* _packetRecBuffer; }; /* * @brief CDF identifier */ CDFid _cdfid; /* * @brief Working buffers container */ boost::shared_ptr _workingBuffers; /* * @brief Get CDF variable Info from param name */ bool getCDFVarInfo(std::string paramName, CDFVarInfo& varInfo); /* * @brief Get CDF data for paramId from startRec to the end of the file */ bool getCDFData(std::string& varId, long startRec, CDFWorkingBuffers::BufferType bufferType, long& dataType, long& numBytes, long& nbRec, long& dimSize); /* * @brief Extract a short to a CDF data buffer */ bool extractShort(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, short& value); /* * @brief Extract a int to a CDF data buffer */ bool extractInt(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, int& value); /* * @brief Extract a float to a CDF data buffer */ bool extractFloat(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, float& value); /* * @brief Extract a int to a CDF data buffer */ bool extractDouble(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, double& value); /* * @brief Extract a Epoch16 to a CDF data buffer */ bool extractEpoch16(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, double value[]); /* * @brief Extract a TT2000 to a CDF data buffer */ bool extractTT2000(CDFWorkingBuffers::BufferType bufferType, long recIndex, long dimIndex, long dimSize, long dataType, long numBytes, long long& value); }; } /* SpeasyProxyInterface */ } /* AMDA */ #endif /* FILEREADERCDF_HH_ */