]> Creatis software - creaImageIO.git/blobdiff - appli/gimmick/main.cxx
*** empty log message ***
[creaImageIO.git] / appli / gimmick / main.cxx
index bee8ff1c269aa6b2137bbd82c9d695eaa1854764..b064a25829d19c22f0706e81a9681f42ddff3e6d 100644 (file)
@@ -1,5 +1,5 @@
 #include <boost/program_options.hpp>
+
 using namespace boost;
 namespace po = boost::program_options;
 
@@ -25,18 +25,21 @@ int main(int ac, char* av[])
   po::options_description command("COMMANDS");
   command.add_options()
     ("print,p","Prints the local database tree  (default=off)")
-    ("file,f",po::value< vector<string> >(),"Adds the file to the local database")
+    ("files,f",po::value< vector<string> >(),"Adds the file(s) to the local database")
     ("dir,d",po::value< vector<string> >(),"Adds the directory to the local database")
-    ("sync,s","Synchronizes the local database with the files")
-    ("recurse,r","Recurse into sub-directories  (default=off)");
-  
+    ("sync,s",po::value< vector<string> >(),"Synchronizes the local database with the files")
+       ("copy,c",po::value< vector<string> >(),"Copies the files into a local directory");
+
   //Describes third group of options
   po::options_description option("OPTIONS");
   option.add_options()
     ("verbose,v",po::value<int>(&verb),"Verbosity level (default=`1')")
-    ("debug,D",po::value<int>(&deb),"Debug messages level (default=`0')");
-  
-  
+    ("debug,D",po::value<int>(&deb),"Debug messages level (default=`0')")
+       ("recurse,r","Recurse into sub-directories  (default=off)")
+       ("repair,R","Repair the database (on synchronization) (default=off)")
+       ("check,C","Check for attribute differences (on synchronization) (default=off)")
+       ("handler,H",po::value<string>(&handler),"Handler name (default=`Local database')");
   //Adds the groups into a big one
   po::options_description cmdline_options;
   cmdline_options.add(generic).add(command).add(option);
@@ -46,6 +49,7 @@ int main(int ac, char* av[])
   po::store(po::parse_command_line(ac, av, cmdline_options), vm);
   po::notify(vm);    
   
+  
   //Does something on each option
   //GENERIC
   if (vm.count("help")) {
@@ -71,7 +75,9 @@ int main(int ac, char* av[])
        ||vm.count("file")
        ||vm.count("dir")
        ||vm.count("sync")
+       ||vm.count("copy")
        )
+  {
 
     try
       {
@@ -86,17 +92,36 @@ int main(int ac, char* av[])
        }
        if (vm.count("dir")) {
          std::vector<std::string> dirs=vm["dir"].as< vector<string> >();
-         g.AddDir(handler,dirs.front(), vm.count("recurse"));
+         bool recu=false;
+         std::stringstream out;
+         out<<vm.count("recurse");
+         if(out.str().compare("1")==0){recu=true;}
+         g.AddDir(handler,dirs.front(), recu);
        }
        if (vm.count("sync")) {
-         g.Synchronize(true,g.GetTreeHandler(handler));
+         bool rep=false;
+      bool chk=false;
+         std::vector<std::string> name=vm["sync"].as< vector<string> >();
+         std::stringstream out;
+         out<<vm.count("repair");
+         if(out.str().compare("1")==0){rep=true;}
+         std::stringstream out2;
+         out2<<vm.count("check");
+         if(out2.str().compare("1")==0){chk=true;}
+         cout<<g.Synchronize(name.front(),rep,chk)<<"\n";
        }       
+       if (vm.count("copy")) {
+         std::vector<std::string> name=vm["copy"].as< vector<string> >();
+         g.CopyFiles(name,handler);
+       }
        g.Finalize();
       }
     catch (crea::Exception e)
       {
        e.Print();
       }
+  }
+         
   
   return 0;
 }