X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/b5bb9df73bd92a33ce4e350a94829ff67e3afca8..b13049b02df74e31a311cf41eb0c61f1898ce77e:/configcache.h?ds=inline diff --git a/configcache.h b/configcache.h index e61bb3f..74998c7 100644 --- a/configcache.h +++ b/configcache.h @@ -5,18 +5,14 @@ #include #include #include +#include -#include -#include -#include -#include -#include +#include "datread.h" -#include "writeout.h" - -#define CACHE_MODE_DISABLED 0 -#define CACHE_MODE_READ 1 -#define CACHE_MODE_FULL 2 +#define CACHE_MODE_OO 0 +#define CACHE_MODE_RO 1 +#define CACHE_MODE_WO 2 +#define CACHE_MODE_RW 3 using namespace std; @@ -25,39 +21,55 @@ struct parameter{ double val; }; +struct infiledesc { + string filename; + int nequi; + int nskip; + bool extended; + bool superextended; +}; + class configcache{ public: ~configcache(); configcache(const string& cacheid, const int& nequi, const int& nskip, const string& datadir, char **configmem, const int& configMemSize, - const int& cachemode=CACHE_MODE_FULL, writeout *out_a=NULL); - bool readConfig(); - void writeConfig(); + const int& cachemode=CACHE_MODE_RW, ostream *_log=NULL); + void readConfig(bool *readnewconfig, int *nequileft, vector *excludeFileHashes=NULL); + void writeConfig(int actnequi); void addPara(const string& parid, const double& val=0); void setPara(const string& parid, const double& value); - - private: - string openFileName; + void writeHeader(const string& headerid, const char *header, long unsigned int size, int actnequi); + void * getHeader(const string& headerid); + string getOutFileName() { return outFileName.str(); } + string getInFileName() { return DATADIR + "/" + openFileDesc.filename; } + static unsigned long hash(const string& str); + void closeInFile() { dataReader->closeFile(); } + int inFilesLeft() { return inFiles.size(); } + char* getConfigMem() { return configMem; } + int getConfigSize() { return configSize; } + bool isOutFileOpen () { return outFile.is_open(); } void finishOutFile(); + + private: + struct iobuffers; + iobuffers *ioBuffers; + + ostream* log; + infiledesc openFileDesc; int getParIndex(const string& parid); int NEQUI; int NSKIP; string DATADIR; string CACHEID; int MODE; - string getFileId(const bool& shortid=false); + string getFileId(int actnequi, const bool& superextended=true, const bool& shortid=false); ofstream outFile; - ifstream inFile; - - writeout *out; stringstream outFileName; int readnum; - boost::iostreams::filtering_istreambuf *inBuffer; - boost::iostreams::filtering_ostreambuf *outBuffer; - int inSize; int configSize; @@ -68,11 +80,29 @@ class configcache{ void fetchDataFiles(); - bool isValidInFile(const string& infile); + bool isValidInFile(const string& infile, infiledesc *filedesc); - vector inFiles; + vector inFiles; vector Paras; + + void openOutFile(int actnequi); + + int readHeader(); + + bool headerWritten; + + bool readAllHeaders(); + + vector::iterator getNextInfile(vector *excludeFileHashes); + + int nequileft_internal; + + bool doVirtualEquilibration, firstUsedConfig; + + string paraString(); + + datread *dataReader; }; #endif