diff options
author | Michi Henning <michi@zeroc.com> | 2004-12-16 03:15:51 +0000 |
---|---|---|
committer | Michi Henning <michi@zeroc.com> | 2004-12-16 03:15:51 +0000 |
commit | b5c3efca572afd6c9cadbc87e9f4c068d312d928 (patch) | |
tree | e34f481e7ed94f176fcbe266767fea241dc3c764 /cpp/src/IcePatch2/Calc.cpp | |
parent | remove now returns null if the key is not found (diff) | |
download | ice-b5c3efca572afd6c9cadbc87e9f4c068d312d928.tar.bz2 ice-b5c3efca572afd6c9cadbc87e9f4c068d312d928.tar.xz ice-b5c3efca572afd6c9cadbc87e9f4c068d312d928.zip |
Changed command line parsing to use IceUtil::Options.
Diffstat (limited to 'cpp/src/IcePatch2/Calc.cpp')
-rw-r--r-- | cpp/src/IcePatch2/Calc.cpp | 104 |
1 files changed, 56 insertions, 48 deletions
diff --git a/cpp/src/IcePatch2/Calc.cpp b/cpp/src/IcePatch2/Calc.cpp index 10dc84ef1d2..1621c63f196 100644 --- a/cpp/src/IcePatch2/Calc.cpp +++ b/cpp/src/IcePatch2/Calc.cpp @@ -7,6 +7,7 @@ // // ********************************************************************** +#include <IceUtil/Options.h> #include <IcePatch2/Util.h> #ifdef _WIN32 @@ -115,63 +116,70 @@ main(int argc, char* argv[]) string dataDir; StringSeq fileSeq; int compress = 1; - bool caseInsensitive = false; - bool verbose = false; + bool verbose; + bool caseInsensitive; - int i; - for(i = 1; i < argc; ++i) + IceUtil::Options opts; + opts.addOpt("h", "help"); + opts.addOpt("v", "version"); + opts.addOpt("z", "compress"); + opts.addOpt("Z", "no-compress"); + opts.addOpt("V", "verbose"); + opts.addOpt("i", "case-insensitive"); + + vector<string> args; + try + { + args = opts.parse(argc, argv); + } + catch(const IceUtil::Options::BadOpt& e) + { + cerr << e.reason << endl; + usage(argv[0]); + return EXIT_FAILURE; + } + + if(opts.isSet("h") || opts.isSet("help")) + { + usage(argv[0]); + return EXIT_SUCCESS; + } + if(opts.isSet("v") || opts.isSet("version")) { - if(strcmp(argv[i], "-h") == 0 || strcmp(argv[i], "--help") == 0) - { - usage(argv[0]); - return EXIT_SUCCESS; - } - else if(strcmp(argv[i], "-v") == 0 || strcmp(argv[i], "--version") == 0) - { - cout << ICE_STRING_VERSION << endl; - return EXIT_SUCCESS; - } - else if(strcmp(argv[i], "-z") == 0 || strcmp(argv[i], "--compress") == 0) - { - compress = 2; - } - else if(strcmp(argv[i], "-Z") == 0 || strcmp(argv[i], "--no-compress") == 0) - { - compress = 0; - } - else if(strcmp(argv[i], "-i") == 0 || strcmp(argv[i], "--case-insensitive") == 0) - { - caseInsensitive = true; - } - else if(strcmp(argv[i], "-V") == 0 || strcmp(argv[i], "--verbose") == 0) - { - verbose = true; - } - else if(argv[i][0] == '-') - { - cerr << argv[0] << ": unknown option `" << argv[i] << "'" << endl; - usage(argv[0]); - return EXIT_FAILURE; - } - else - { - if(dataDir.empty()) - { - dataDir = normalize(argv[i]); - } - else - { - fileSeq.push_back(normalize(argv[i])); - } - } + cout << ICE_STRING_VERSION << endl; + return EXIT_SUCCESS; } + bool doCompress = opts.isSet("z") || opts.isSet("compress"); + bool dontCompress = opts.isSet("Z") || opts.isSet("no-compress"); + if(doCompress && dontCompress) + { + cerr << argv[0] << ": only one of -z and -Z are mutually exclusive" << endl; + usage(argv[0]); + return EXIT_FAILURE; + } + if(doCompress) + { + compress = 2; + } + else if(dontCompress) + { + compress = 0; + } + verbose = opts.isSet("V") || opts.isSet("verbose"); + caseInsensitive = opts.isSet("i") || opts.isSet("case-insensitive"); - if(dataDir.empty()) + if(args.empty()) { cerr << argv[0] << ": no data directory specified" << endl; usage(argv[0]); return EXIT_FAILURE; } + dataDir = normalize(args[0]); + + for(vector<string>::size_type i = 1; i < args.size(); ++i) + { + fileSeq.push_back(normalize(args[i])); + } try { |