summaryrefslogtreecommitdiff
path: root/cpp/src/IcePatch2/Calc.cpp
diff options
context:
space:
mode:
authorMichi Henning <michi@zeroc.com>2004-12-16 03:15:51 +0000
committerMichi Henning <michi@zeroc.com>2004-12-16 03:15:51 +0000
commitb5c3efca572afd6c9cadbc87e9f4c068d312d928 (patch)
treee34f481e7ed94f176fcbe266767fea241dc3c764 /cpp/src/IcePatch2/Calc.cpp
parentremove now returns null if the key is not found (diff)
downloadice-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.cpp104
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
{