X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/ad54f29de351976a096b4991fe426ffc30332df2..a477390b3aa6eea3a7d822a0499816eb0e2bf499:/configcache.h diff --git a/configcache.h b/configcache.h index 82fa3f6..8146b27 100644 --- a/configcache.h +++ b/configcache.h @@ -28,7 +28,6 @@ struct infiledesc { string filename; int nequi; int nskip; - bool doVirtualEquilibration; bool extended; }; @@ -37,17 +36,19 @@ class configcache{ ~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, ostream *_log=NULL); - int readConfig(vector *excludeFileHashes=NULL); - void writeConfig(); + 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); - void writeHeader(const string& headerid, const char *header, long unsigned int size); + 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() { inFile.close(); } int inFilesLeft() { return inFiles.size(); } + char* getConfigMem() { return configMem; } + int getConfigSize() { return configSize; } private: ostream* log; @@ -59,7 +60,7 @@ class configcache{ string DATADIR; string CACHEID; int MODE; - string getFileId(const bool& shortid=false); + string getFileId(int actnequi, const bool& shortid=false); ofstream outFile; ifstream inFile; @@ -89,7 +90,7 @@ class configcache{ int readDataToMem(char *tmpData, long unsigned int dataSize); - void openOutFile(); + void openOutFile(int actnequi); int readHeader(); @@ -104,6 +105,10 @@ class configcache{ bool readAllHeaders(); vector::iterator getNextInfile(vector *excludeFileHashes); + + int nequileft_internal; + + bool doVirtualEquilibration, firstUsedConfig; }; #endif