X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fsession_state_utils.cc;h=28cfbb2b756eb6019f4ca2bcb06f032a2cce46e2;hb=77bd398153240390362fea83533627e6d767ddb3;hp=a8550724136b536ca278200649a5184908baee31;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/libs/ardour/session_state_utils.cc b/libs/ardour/session_state_utils.cc index a855072413..28cfbb2b75 100644 --- a/libs/ardour/session_state_utils.cc +++ b/libs/ardour/session_state_utils.cc @@ -18,6 +18,11 @@ #include +#include + +#include + +#include "pbd/basename.h" #include "pbd/compose.h" #include "pbd/error.h" #include "pbd/file_utils.h" @@ -25,7 +30,7 @@ #include "ardour/session_state_utils.h" #include "ardour/filename_extensions.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace std; using namespace PBD; @@ -33,43 +38,26 @@ using namespace PBD; namespace ARDOUR { bool -create_backup_file (const sys::path & file_path) +create_backup_file (const std::string & file_path) { - if (!sys::exists (file_path)) return false; - - sys::path backup_path(file_path.to_string() + backup_suffix); - - try - { - sys::copy_file (file_path, backup_path); - } - catch(sys::filesystem_error& ex) - { - error << string_compose (_("Unable to create a backup copy of file %1 (%2)"), - file_path.to_string(), ex.what()) - << endmsg; - return false; - } - return true; + return copy_file (file_path, file_path + backup_suffix); } void -get_state_files_in_directory (const sys::path & directory_path, - vector & result) +get_state_files_in_directory (const std::string & directory_path, + vector & result) { - Glib::PatternSpec state_file_pattern('*' + string(statefile_suffix)); - - find_matching_files_in_directory (directory_path, state_file_pattern, - result); + find_files_matching_pattern (result, directory_path, + '*' + string(statefile_suffix)); } vector -get_file_names_no_extension (const vector & file_paths) +get_file_names_no_extension (const vector & file_paths) { vector result; std::transform (file_paths.begin(), file_paths.end(), - std::back_inserter(result), sys::basename); + std::back_inserter(result), PBD::basename_nosuffix); sort (result.begin(), result.end(), std::less());