aboutsummaryrefslogtreecommitdiffstats
path: root/src/options.cpp
diff options
context:
space:
mode:
authorThiago Macieira <thiago@cassini.local.lan>2007-12-24 10:48:00 -0200
committerThiago Macieira <thiago@cassini.local.lan>2007-12-24 10:48:00 -0200
commit1228bd7c87f4e203883086d6884280653a8d1777 (patch)
tree659996b6c17d520e07ee4362307a0711d8745562 /src/options.cpp
parent14ddd2a51aa3a917bbb7fbade842818ab09802bc (diff)
downloadsvn2git-1228bd7c87f4e203883086d6884280653a8d1777.tar
svn2git-1228bd7c87f4e203883086d6884280653a8d1777.tar.gz
svn2git-1228bd7c87f4e203883086d6884280653a8d1777.tar.bz2
svn2git-1228bd7c87f4e203883086d6884280653a8d1777.tar.xz
svn2git-1228bd7c87f4e203883086d6884280653a8d1777.zip
Add a better option-parser
Diffstat (limited to 'src/options.cpp')
-rw-r--r--src/options.cpp126
1 files changed, 126 insertions, 0 deletions
diff --git a/src/options.cpp b/src/options.cpp
new file mode 100644
index 0000000..69ae719
--- /dev/null
+++ b/src/options.cpp
@@ -0,0 +1,126 @@
+/*
+ * Copyright (C) 2007 Thiago Macieira <thiago@kde.org>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "options.h"
+
+#include <QSet>
+#include <QStringList>
+
+#include <stdio.h>
+#include <stdlib.h>
+
+Options* Options::globalOptions = 0;
+
+Options::Options()
+{
+ globalOptions = this;
+}
+
+Options::~Options()
+{
+}
+
+void Options::showHelp()
+{
+ printf("Usage: svn-all-fast-export configfile path-to-svn\n");
+}
+
+void Options::parseArguments(const QStringList &argumentList)
+{
+ QSet<QString> validOptions;
+ validOptions << "help";
+
+ QHash<QString, QString> optionsWithComplement;
+ optionsWithComplement.insert("resume-from", QString());
+ optionsWithComplement.insert("identity-map", QString());
+
+ QStringList arguments = argumentList;
+ arguments.takeFirst(); // the first one is the executable name; drop it
+ while (!arguments.isEmpty()) {
+ QString arg = arguments.takeFirst();
+ QString complement;
+
+ if (arg == "--")
+ break;
+
+ if (arg.startsWith("--"))
+ arg = arg.mid(1); // drop double dashes to single
+
+ if (arg.startsWith("-no-")) {
+ complement = "no";
+ arg = arg.mid(4);
+ } else if (!arg.startsWith("-")) {
+ // non-option arg
+ break;
+ } else { // starts with "-"
+ arg = arg.mid(1);
+ }
+
+ if (arg.contains('=') && complement.isEmpty()) {
+ int pos = arg.indexOf('=');
+ complement = arg.mid(pos + 1);
+ arg.truncate(pos);
+ }
+
+ if (optionsWithComplement.contains(arg)) {
+ if (arguments.isEmpty()) {
+ fprintf(stderr, "Option -%s requires an argument", qPrintable(arg));
+ exit(2);
+ }
+
+ QString &setting = optionsWithComplement[arg];
+ if (!setting.isNull()) {
+ fprintf(stderr, "Option -%s given more than once", qPrintable(arg));
+ exit(2);
+ }
+
+ if (!complement.isEmpty())
+ setting = complement;
+ else if (!arguments.isEmpty())
+ setting = arguments.takeFirst();
+ else {
+ fprintf(stderr, "Option -%s requires an argument", qPrintable(arg));
+ exit(2);
+ }
+ continue;
+ } else if (validOptions.contains(arg)) {
+ if (switches.contains(arg)) {
+ fprintf(stderr, "Option -%s given more than once", qPrintable(arg));
+ exit(2);
+ }
+
+ switches[arg] = !(complement == "no");
+ } else {
+ if (complement == "no")
+ fprintf(stderr, "Invalid option: -no-%s", qPrintable(arg));
+ else
+ fprintf(stderr, "Invalid option: -%s", qPrintable(arg));
+ exit(2);
+ }
+ }
+
+ if (switches.value("help")) {
+ showHelp();
+ exit(0);
+ } else if (arguments.count() < 2) {
+ showHelp();
+ exit(2);
+ }
+
+ ruleFile = arguments.takeFirst();
+ pathToRepository = arguments.takeFirst();
+}