summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--NEWS3
-rw-r--r--src/state.c12
2 files changed, 11 insertions, 4 deletions
diff --git a/NEWS b/NEWS
index 9b3b6e4..e1ca845 100644
--- a/NEWS
+++ b/NEWS
@@ -2,8 +2,9 @@ lilv (0.24.5) unstable;
* Fix GCC8 warnings
* Fix creating directories across drives on Windows
+ * Don't print errors when saving state if correct links already exist
- -- David Robillard <d@drobilla.net> Tue, 04 Sep 2018 21:02:19 +0200
+ -- David Robillard <d@drobilla.net> Sun, 16 Sep 2018 11:04:16 +0200
lilv (0.24.4) stable;
diff --git a/src/state.c b/src/state.c
index 23c1cc4..3c027a7 100644
--- a/src/state.c
+++ b/src/state.c
@@ -884,6 +884,12 @@ link_exists(const char* path, const void* data)
return !matches;
}
+static int
+maybe_symlink(const char* oldpath, const char* newpath)
+{
+ return link_exists(newpath, oldpath) ? 0 : lilv_symlink(oldpath, newpath);
+}
+
static void
write_property_array(const LilvState* state,
const PropertyArray* array,
@@ -1026,7 +1032,7 @@ lilv_state_make_links(const LilvState* state, const char* dir)
&& strcmp(state->copy_dir, dir)) {
// Link directly to snapshot in the copy directory
char* target = lilv_path_relative_to(pm->abs, dir);
- lilv_symlink(target, path);
+ maybe_symlink(target, path);
free(target);
} else if (!lilv_path_is_child(pm->abs, dir)) {
const char* link_dir = state->link_dir ? state->link_dir : dir;
@@ -1034,7 +1040,7 @@ lilv_state_make_links(const LilvState* state, const char* dir)
if (!strcmp(dir, link_dir)) {
// Link directory is save directory, make link at exact path
remove(pat);
- lilv_symlink(pm->abs, pat);
+ maybe_symlink(pm->abs, pat);
} else {
// Make a link in the link directory to external file
char* lpath = lilv_find_free_path(pat, link_exists, pm->abs);
@@ -1044,7 +1050,7 @@ lilv_state_make_links(const LilvState* state, const char* dir)
// Make a link in the save directory to the external link
char* target = lilv_path_relative_to(lpath, dir);
- lilv_symlink(target, path);
+ maybe_symlink(target, path);
free(target);
free(lpath);
}