diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2015-09-23 05:08:35 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-09-23 05:10:43 -0700 |
commit | aeedc2a619564a957c8fca000a7fa0148e3d78b1 (patch) | |
tree | 19792af0b898d1d7cab771e55b4c766e031c0cd7 | |
parent | c7ae8c8655a618de92ca6072dbe51dcea4493cb7 (diff) | |
download | subsurface-aeedc2a619564a957c8fca000a7fa0148e3d78b1.tar.gz |
Add helper function to safely move away file or directory
Try numberical suffix until you find one that isn't used yet.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | qthelper.cpp | 22 | ||||
-rw-r--r-- | qthelperfromc.h | 1 |
2 files changed, 23 insertions, 0 deletions
diff --git a/qthelper.cpp b/qthelper.cpp index 6e3c957a6..3a4daf833 100644 --- a/qthelper.cpp +++ b/qthelper.cpp @@ -627,6 +627,28 @@ extern "C" const char *system_default_directory(void) return filename; } +extern "C" char *move_away(const char *old_path) +{ + if (verbose > 1) + qDebug() << "move away" << old_path; + QFile oldFile(old_path); + QFile newFile; + QString newPath; + int i = 0; + do { + newPath = QString(old_path) + QString(".%1").arg(++i); + newFile.setFileName(newPath); + } while(newFile.exists()); + if (verbose > 1) + qDebug() << "renaming to" << newPath; + if (!oldFile.rename(newPath)) { + qDebug() << "rename of" << old_path << "to" << newPath << "failed"; + return strdup(""); + } + return strdup(qPrintable(newPath)); + +} + extern "C" char *get_file_name(const char *fileName) { QFileInfo fileInfo(fileName); diff --git a/qthelperfromc.h b/qthelperfromc.h index d64bfc04a..21b2a6f80 100644 --- a/qthelperfromc.h +++ b/qthelperfromc.h @@ -10,6 +10,7 @@ char *get_file_name(const char *fileName); void copy_image_and_overwrite(const char *cfileName, const char *path, const char *cnewName); char *hashstring(char *filename); bool picture_exists(struct picture *picture); +char *move_away(const char *path); const char *local_file_path(struct picture *picture); void savePictureLocal(struct picture *picture, const char *data, int len); void cache_picture(struct picture *picture); |