]> andersk Git - svn-all-fast-export.git/blobdiff - src/main.cpp
Support Qt 4.3 too
[svn-all-fast-export.git] / src / main.cpp
index bf7af7648ddc9bc06a2c165d76f396c80b43a671..8308eb6d5deed93d97dabd18cab8c05b7b39268b 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);
@@ -45,8 +70,6 @@ int main(int argc, char **argv)
     QHash<QString, Repository *> repositories;
     foreach (Rules::Repository rule, rules.repositories()) {
         Repository *repo = new Repository(rule);
-        if (min_rev > 1)
-            repo->reloadBranches();
         repositories.insert(rule.name, repo);
     }
 
@@ -54,6 +77,7 @@ 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")));
 
     if (max_rev < 1)
         max_rev = svn.youngestRevision();
This page took 0.10086 seconds and 4 git commands to generate.