]> andersk Git - svn-all-fast-export.git/blobdiff - src/main.cpp
Initialize variable
[svn-all-fast-export.git] / src / main.cpp
index 2ce11c592e0c86c18d3de69f6578319328eab4f1..9ad54771d6a8fd4e1a6f9baf611edf3f40dd4198 100644 (file)
@@ -16,6 +16,7 @@
  */
 
 #include <QCoreApplication>
+#include <QFile>
 #include <QStringList>
 
 #include <stdio.h>
 #include "repository.h"
 #include "svn.h"
 
+QHash<QByteArray, QByteArray> loadIdentityMapFile(const QString &fileName)
+{
+    QHash<QByteArray, QByteArray> result;
+    if (fileName.isEmpty())
+        return result;
+
+    QFile file(fileName);
+    if (!file.open(QIODevice::ReadOnly))
+        return result;
+
+    while (!file.atEnd()) {
+        QByteArray line = file.readLine().trimmed();
+        int space = line.indexOf(' ');
+        if (space == -1)
+            continue;           // invalid line
+
+        QByteArray realname = line.mid(space).trimmed();
+        line.truncate(space);
+        result.insert(line, realname);
+    };
+
+    return result;
+}
+
 int main(int argc, char **argv)
 {
     QCoreApplication app(argc, argv);
@@ -37,6 +62,7 @@ int main(int argc, char **argv)
     rules.load();
 
     int min_rev = options.options.value("resume-from").toInt();
+    int max_rev = options.options.value("max-rev").toInt();
     if (min_rev < 1)
         min_rev = 1;
 
@@ -53,8 +79,10 @@ int main(int argc, char **argv)
     Svn svn(options.pathToRepository);
     svn.setMatchRules(rules.matchRules());
     svn.setRepositories(repositories);
+    svn.setIdentityMap(loadIdentityMapFile(options.options.value("identity-map")));
 
-    int max_rev = svn.youngestRevision();
+    if (max_rev < 1)
+        max_rev = svn.youngestRevision();
     for (int i = min_rev; i <= max_rev; ++i)
         if (!svn.exportRevision(i))
             break;
This page took 0.05577 seconds and 4 git commands to generate.