From 1dbf0a91195c6e8bd4404cc6b922ba35dd5e9b4e Mon Sep 17 00:00:00 2001 From: Colin Guthrie Date: Wed, 28 May 2014 23:34:35 +0100 Subject: Move the repo renaming to a method for convenience. This also renames log and marks files. --- src/repository.cpp | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) (limited to 'src/repository.cpp') 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)); -- cgit v1.2.1