From 0eafb1f3005d0ddf9f8ce8c6bde30f0ac641aa61 Mon Sep 17 00:00:00 2001 From: Paul Davis Date: Fri, 6 Apr 2007 02:48:29 +0000 Subject: [PATCH] fix crashes when handling files with ":" in their paths. Cost: cannot load old sessions with non-mono embedded files anymore git-svn-id: svn://localhost/ardour2/trunk@1672 d708f5d6-7413-0410-9779-e7cbd77b26cf --- gtk2_ardour/editor_audio_import.cc | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/gtk2_ardour/editor_audio_import.cc b/gtk2_ardour/editor_audio_import.cc index df737429bd..2f63de340e 100644 --- a/gtk2_ardour/editor_audio_import.cc +++ b/gtk2_ardour/editor_audio_import.cc @@ -17,6 +17,11 @@ */ +#include +#include +#include +#include + #include #include #include @@ -294,7 +299,7 @@ Editor::embed_sndfile (vector paths, bool split, bool multiple_fi linked_path += Glib::path_get_basename (path); if (link (path.c_str(), linked_path.c_str()) == 0) { - + /* there are many reasons why link(2) might have failed. but if it succeeds, we now have a link in the session sound dir that will protect against @@ -302,6 +307,21 @@ Editor::embed_sndfile (vector paths, bool split, bool multiple_fi */ path = linked_path; + + } else { + + /* one possible reason is that its already linked */ + + if (errno == EEXIST) { + struct stat sb; + + if (stat (linked_path.c_str(), &sb) == 0) { + if (sb.st_nlink > 1) { // its a hard link, assume its the one we want + path = linked_path; + } + } + } + } /* note that we temporarily truncated _id at the colon */