aboutsummaryrefslogtreecommitdiffstats
path: root/src/repository.cpp
diff options
context:
space:
mode:
authorColin Guthrie <colin@mageia.org>2014-05-28 23:34:35 +0100
committerColin Guthrie <colin@mageia.org>2014-05-28 23:50:40 +0100
commit1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e (patch)
tree7369e927673164a656d12a84543dbabfa7873d16 /src/repository.cpp
parent3b270cf149ee67bcf2dace4edec34c91abe13bc5 (diff)
downloadsvn2git-1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e.tar
svn2git-1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e.tar.gz
svn2git-1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e.tar.bz2
svn2git-1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e.tar.xz
svn2git-1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e.zip
Move the repo renaming to a method for convenience.
This also renames log and marks files.
Diffstat (limited to 'src/repository.cpp')
-rw-r--r--src/repository.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/repository.cpp b/src/repository.cpp
index 2fbe2a5..f6ee98a 100644
--- a/src/repository.cpp
+++ b/src/repository.cpp
@@ -127,6 +127,40 @@ static QString logFileName(QString name)
return name;
}
+bool Repository::rename(const QString &newName)
+{
+ if (!QDir(name).exists()) { // repo doesn't exist yet.
+ qCritical() << "Cannot find repository dir for" << name;
+ return false;
+ }
+
+ qDebug() << "repository" << name << "deleted - renaming repo with revision number suffix" << newName;
+ if (!QFile::rename(name, newName)) {
+ qCritical() << "Could not rename repository dir for" << name;
+ return false;
+ }
+
+ if (!QFile::rename(logFileName(name), logFileName(newName))) {
+ qCritical() << "Could not rename logfile for repository" << name;
+ return false;
+ }
+
+ closeFastImport();
+
+ if (!QFile::rename(newName + "/" + marksFileName(name), newName + "/" + marksFileName(newName))) {
+ qCritical() << "Could not rename marks file for repository" << name;
+ return false;
+ }
+
+ name = newName;
+
+ // fastImport will be restarted on next txn
+ fastImport.setWorkingDirectory(name);
+
+ return true;
+}
+
+
static int lastValidMark(QString name)
{
QFile marksfile(name + "/" + marksFileName(name));