From b37f30897dd7a032b97fe87b709c335f9d1cca9d Mon Sep 17 00:00:00 2001 From: Robin Gareus Date: Wed, 12 Jun 2019 21:34:39 +0200 Subject: [PATCH] Windows does in theory support hard-links NB. this is just as unused as the POSIX link() test. Aardour doesn't create hardlinks since version 3.0. At least it's now consistently wrong on all platforms :) --- gtk2_ardour/sfdb_ui.cc | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/gtk2_ardour/sfdb_ui.cc b/gtk2_ardour/sfdb_ui.cc index 67eda8914a..63b09ba3b8 100644 --- a/gtk2_ardour/sfdb_ui.cc +++ b/gtk2_ardour/sfdb_ui.cc @@ -21,6 +21,10 @@ #include "gtk2ardour-config.h" #endif +#ifdef PLATFORM_WINDOWS +#include +#endif + #include #include #include @@ -1696,9 +1700,6 @@ SoundFileOmega::check_info (const vector& paths, bool& same_size, bool& bool SoundFileOmega::check_link_status (const Session* s, const vector& paths) { -#ifdef PLATFORM_WINDOWS - return false; -#else std::string tmpdir(Glib::build_filename (s->session_directory().sound_path(), "linktest")); bool ret = false; @@ -1715,10 +1716,16 @@ SoundFileOmega::check_link_status (const Session* s, const vector& paths snprintf (tmpc, sizeof(tmpc), "%s/%s", tmpdir.c_str(), Glib::path_get_basename (*i).c_str()); /* can we link ? */ - - if (link ((*i).c_str(), tmpc)) { +#ifdef PLATFORM_WINDOWS + /* see also ntfs_link -- msvc only pbd extension */ + if (false == CreateHardLinkA (/*new link*/ tmpc, /*existing file*/ (*i).c_str(), NULL)) { goto out; } +#else + if (link (/*existing file*/(*i).c_str(), tmpc)) { + goto out; + } +#endif ::g_unlink (tmpc); } @@ -1728,7 +1735,6 @@ SoundFileOmega::check_link_status (const Session* s, const vector& paths out: g_rmdir (tmpdir.c_str()); return ret; -#endif } SoundFileChooser::SoundFileChooser (string title, ARDOUR::Session* s)