X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=appli%2Fgimmick%2Fmain.cxx;h=b456e3f48a4b232e3c2f29d36d6f139a13be0849;hb=273d833f9aea7ee060e41a3bf810811640e10ac6;hp=397a4f9f6670a7c84d06b4f9b8b71ff8d5b79305;hpb=bfede4f2084492a14d5d7c68f7d1a60d91865236;p=creaImageIO.git diff --git a/appli/gimmick/main.cxx b/appli/gimmick/main.cxx index 397a4f9..b456e3f 100644 --- a/appli/gimmick/main.cxx +++ b/appli/gimmick/main.cxx @@ -1,55 +1,117 @@ +#include + +using namespace boost; +namespace po = boost::program_options; + #include #include -#include -int main(int argc, char* argv[]) +using namespace std; + +int main(int ac, char* av[]) { - gengetopt_args_info args; - if (cmdline_parser (argc, argv, &args) != 0) return 0 ; - + creaImageIO::Gimmick g; - if (args.verbose_given) g.SetMessageLevel(args.verbose_arg); - if (args.debug_given) g.SetDebugMessageLevel(args.debug_arg); - - bool something_to_do = - args.dir_given | - args.file_given | - args.print_given; + int verb,deb; + std::string handler("Local database"); + + //Describes first group of options + po::options_description generic("GENERIC"); + generic.add_options() + ("help,h", "Print help and exit") + ("version,V", "Print version and exit"); + + //Describes second group of options + po::options_description command("COMMANDS"); + command.add_options() + ("print,p","Prints the local database tree (default=off)") + ("file,f",po::value< vector >(),"Adds the file to the local database") + ("dir,d",po::value< vector >(),"Adds the directory to the local database") + ("sync,s","Synchronizes the local database with the files") + ("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)"); - if (!something_to_do) - { - std::cout << "Nothing to do !" << std::endl; - return 0; - } + + //Describes third group of options + po::options_description option("OPTIONS"); + option.add_options() + ("verbose,v",po::value(&verb),"Verbosity level (default=`1')") + ("debug,D",po::value(&deb),"Debug messages level (default=`0')"); + + //Adds the groups into a big one + po::options_description cmdline_options; + cmdline_options.add(generic).add(command).add(option); + + //Adds the corresponding variables + po::variables_map vm; + po::store(po::parse_command_line(ac, av, cmdline_options), vm); + po::notify(vm); + + //Does something on each option + //GENERIC + if (vm.count("help")) { + cout << "Usage: gimmick COMMAND [OPTIONS]:\n"; + cout << cmdline_options << "\n"; + } + if (vm.count("version")) { + cout << "gimmick 0.1.0\n"; + } + + //OPTIONS + if (vm.count("verbose")) { + g.SetMessageLevel(verb); + cout << "Verbose level is now "< files; - // TO DO : multiple files given - files.push_back(args.file_arg); - g.AddFiles(handler,files); - } - if (args.dir_given) - { - g.AddDir(handler,args.dir_arg, args.recurse_given); - } - - if (args.print_given) - { + try + { + g.Initialize(); + if (vm.count("print")) { g.GetTreeHandler(handler)->LoadChildren(0,0); g.Print(handler); } - - g.Finalize(); - } - catch (crea::Exception e) - { - e.Print(); - } + if (vm.count("file")) { + std::vector files=vm["file"].as< vector >(); + g.AddFiles(handler,files); + } + if (vm.count("dir")) { + std::vector dirs=vm["dir"].as< vector >(); + bool recu=false; + std::stringstream out; + out<