]> Creatis software - creaImageIO.git/blobdiff - src2/creaImageIOGimmick.cpp
*** empty log message ***
[creaImageIO.git] / src2 / creaImageIOGimmick.cpp
index 64099e589c651e2bbf37fe4fefa1667cfcc7ef0a..21d9cd4d01a966e8dd5d60a23f309bfcff8d2763 100644 (file)
@@ -8,14 +8,12 @@
 
 namespace creaImageIO
 {
-  
+
+
   //==============================================================
   Gimmick::Gimmick()
   {    
-    crea::MessageManager::RegisterMessageType("Gimmick!",
-                                             "Gimmick",1);
-    crea::MessageManager::RegisterMessageType("Gimmick! DEBUG",
-                                             "Gimmick",0);
+    RegisterGimmickMessageTypes();
   }
   //==============================================================
 
@@ -39,6 +37,9 @@ namespace creaImageIO
 
     // Create local database handler
     mLocalDatabase = new SQLiteTreeHandler(GetLocalDatabasePath());
+    // Add it to the TreeHandlerMap
+    mTreeHandlerMap["Local database"] = mLocalDatabase;
+
     // Create or open local database
     if (! boost::filesystem::exists( GetLocalDatabasePath() ) )
       {
@@ -154,7 +155,7 @@ namespace creaImageIO
   /// Sets message level
   void Gimmick::SetMessageLevel(int l)
   {
-    crea::MessageManager::SetMessageLevel("Gimmick!",l);
+    SetGimmickMessageLevel(l);
   }
   //========================================================================
 
@@ -162,15 +163,31 @@ namespace creaImageIO
   /// Sets message level
   void Gimmick::SetDebugMessageLevel(int l)
   {
-    crea::MessageManager::SetMessageLevel("Gimmick! DEBUG",l);
+    SetGimmickDebugMessageLevel(l);
   }
   //========================================================================
 
   //========================================================================
   /// Add a file to the local database
-  void Gimmick::AddFileToLocalDatabase(const std::string& f)
+  TreeHandler* Gimmick::GetTreeHandler(const std::string& name) const 
+  {  
+    TreeHandlerMapType::const_iterator i;
+    i = GetTreeHandlerMap().find(name);
+    if ( i == GetTreeHandlerMap().end() )
+      {
+       GimmickError("TreeHandler '"<<name<<"' does not exist");
+      }
+    return i->second;
+  }
+
+
+  //========================================================================
+  /// Add a file to the local database
+  void Gimmick::AddFile(const std::string& d, const std::string& f)
   {
-    ImageFinder finder(mLocalDatabase);
+    GimmickMessage(2,"Adding file '"<<f<<"' to '"<<d<<"'"<<std::endl);
+    ImageFinder finder(GetTreeHandler(d));
     if (finder.IsHandledFile(f)) 
       {
        finder.AddFile(f);
@@ -184,9 +201,13 @@ namespace creaImageIO
 
   //========================================================================
   /// Add a dir to the local database
-  void Gimmick::AddDirToLocalDatabase(const std::string& f, bool recurse)
+  void Gimmick::AddDir(const std::string& d, const std::string& f, 
+                      bool recurse)
   {
-    ImageFinder finder(mLocalDatabase);
+    GimmickMessage(2,"Adding dir '"<<f<<"' to '"<<d<<"' recurse:"
+                  <<recurse<<std::endl);
+
+    ImageFinder finder(GetTreeHandler(d));
     
     finder.AddDirectory(f,recurse);
     
@@ -195,9 +216,9 @@ namespace creaImageIO
 
   //========================================================================
   /// 
-  void Gimmick::PrintLocalDatabase()
+  void Gimmick::Print(const std::string& d)
   {
-    mLocalDatabase->GetTree().Print();
+    GetTreeHandler(d)->GetTree().Print();
   }
   //========================================================================