]> git.treefish.org Git - phys/latlib.git/blobdiff - hypercache.h
only storing concurrent config file HASHES instead of full names.
[phys/latlib.git] / hypercache.h
index 53e0f676ceea47c4404268de565af1df32072f71..11e1565148047d926370cbe9f73b12d522fc96a0 100644 (file)
@@ -11,55 +11,49 @@ class hypercache {
  public:
   static void initO(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) {
  public:
   static void initO(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) {
-    initCache(O, cacheid, nequi, nskip, datadir+"/o", configmem, configMemSize, cachemode, out_a);
+    initCache(&O, cacheid, nequi, nskip, datadir, configmem, configMemSize, cachemode, out_a);
   }
   static void initC(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) {
   }
   static void initC(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) {
-    initCache(C, cacheid, nequi, nskip, datadir+"/c", configmem, configMemSize, cachemode, out_a);
-  }
-  
-  static void initO(const string& cacheid, char **configmem, const int& configMemSize, const int& cachemode=CACHE_MODE_FULL) {
-    initCache(O, "o", cacheid, configmem, configMemSize, cachemode);
-  }
-  static void initC(const string& cacheid, char **configmem, const int& configMemSize, const int& cachemode=CACHE_MODE_FULL) {
-    initCache(C, "c", cacheid, configmem, configMemSize, cachemode);
+    initCache(&C, cacheid, nequi, nskip, datadir, configmem, configMemSize, cachemode, out_a);
   }
   
   static void addPara(const string& parid, const double& val=0);
   static void setPara(const string& parid, const double& value);
   }
   
   static void addPara(const string& parid, const double& val=0);
   static void setPara(const string& parid, const double& value);
-  static bool readO() { return O->readConfig(); }
-  static bool readC() { return C->readConfig(); }
-  static void writeO() { O->writeConfig(); }
-  static void writeC() { C->writeConfig(); }
+  static bool readO();
+  static bool readC();
+  static void writeO();
+  static void writeC();
   static void writeHeaderO(const string& headerid, char *header, long unsigned int size) { O->writeHeader(headerid, header, size); }
   static void *getHeaderO(const string& headerid) { O->getHeader(headerid); }
   static void writeHeaderC(const string& headerid, char *header, long unsigned int size) { C->writeHeader(headerid, header, size); }
   static void *getHeaderC(const string& headerid) { C->getHeader(headerid); }
   static void writeHeaderO(const string& headerid, char *header, long unsigned int size) { O->writeHeader(headerid, header, size); }
   static void *getHeaderO(const string& headerid) { O->getHeader(headerid); }
   static void writeHeaderC(const string& headerid, char *header, long unsigned int size) { C->writeHeader(headerid, header, size); }
   static void *getHeaderC(const string& headerid) { C->getHeader(headerid); }
+
+  static void finalize();
   
  private:
   
  private:
-  struct defaults{
-    int nequi;
-    int nskip;
-    string datadir;
-    writeout *out;
-  };
   struct para{
     string parid;
     double val;
   };
 
   struct para{
     string parid;
     double val;
   };
 
-  static void initCache(configcache *cache,
+  static void initCache(configcache **cache,
                        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); 
 
                        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); 
 
-  static void initCache( configcache *cache, const string& subdir,
+  static void initCache( configcache **cache,
                         const string& cacheid, char **configmem, const int& configMemSize, const int& cachemode=CACHE_MODE_FULL);
                         const string& cacheid, char **configmem, const int& configMemSize, const int& cachemode=CACHE_MODE_FULL);
-  
+
   static configcache *O;
   static configcache *C;
   static configcache *O;
   static configcache *C;
-  static defaults *Defaults; 
   static vector<para> delayedParaAdd;
   static vector<para> delayedParaSet;
   static vector<para> delayedParaAdd;
   static vector<para> delayedParaSet;
+  static writeout *out;
+
+  static string fileOfPath(const string& dressedfile);
+  static string activeCFile;
+  static vector<unsigned long> parentConfigs;
+  static void addParentConfig(const unsigned long *parentconfig);
 };
 
 #endif
 };
 
 #endif