mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-12 09:17:52 -06:00
copy file into .tmp and then rename if correct
This commit is contained in:
parent
dafd768b34
commit
31b134bfcc
2 changed files with 34 additions and 18 deletions
|
@ -65,6 +65,7 @@ extern std::string normalize_utf8_nfc(const char *src);
|
||||||
extern std::error_code rename_file(const std::string &from, const std::string &to);
|
extern std::error_code rename_file(const std::string &from, const std::string &to);
|
||||||
|
|
||||||
// Copy a file, adjust the access attributes, so that the target is writable.
|
// Copy a file, adjust the access attributes, so that the target is writable.
|
||||||
|
int copy_file_inner(const std::string &from, const std::string &to);
|
||||||
extern int copy_file(const std::string &from, const std::string &to, const bool with_check = false);
|
extern int copy_file(const std::string &from, const std::string &to, const bool with_check = false);
|
||||||
|
|
||||||
// Compares two files, returns 0 if identical.
|
// Compares two files, returns 0 if identical.
|
||||||
|
|
|
@ -417,26 +417,41 @@ std::error_code rename_file(const std::string &from, const std::string &to)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int copy_file_inner(const std::string& from, const std::string& to)
|
||||||
|
{
|
||||||
|
const boost::filesystem::path source(from);
|
||||||
|
const boost::filesystem::path target(to);
|
||||||
|
static const auto perms = boost::filesystem::owner_read | boost::filesystem::owner_write | boost::filesystem::group_read | boost::filesystem::others_read; // aka 644
|
||||||
|
|
||||||
|
// Make sure the file has correct permission both before and after we copy over it.
|
||||||
|
// NOTE: error_code variants are used here to supress expception throwing.
|
||||||
|
// Error code of permission() calls is ignored on purpose - if they fail,
|
||||||
|
// the copy_file() function will fail appropriately and we don't want the permission()
|
||||||
|
// calls to cause needless failures on permissionless filesystems (ie. FATs on SD cards etc.)
|
||||||
|
// or when the target file doesn't exist.
|
||||||
|
boost::system::error_code ec;
|
||||||
|
boost::filesystem::permissions(target, perms, ec);
|
||||||
|
boost::filesystem::copy_file(source, target, boost::filesystem::copy_option::overwrite_if_exists, ec);
|
||||||
|
if (ec) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
boost::filesystem::permissions(target, perms, ec);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int copy_file(const std::string &from, const std::string &to, const bool with_check)
|
int copy_file(const std::string &from, const std::string &to, const bool with_check)
|
||||||
{
|
{
|
||||||
const boost::filesystem::path source(from);
|
std::string to_temp = to + ".tmp";
|
||||||
const boost::filesystem::path target(to);
|
int ret_val = copy_file_inner(from,to_temp);
|
||||||
static const auto perms = boost::filesystem::owner_read | boost::filesystem::owner_write | boost::filesystem::group_read | boost::filesystem::others_read; // aka 644
|
if(ret_val == 0 && with_check)
|
||||||
|
{
|
||||||
// Make sure the file has correct permission both before and after we copy over it.
|
ret_val = check_copy(from, to_temp);
|
||||||
// NOTE: error_code variants are used here to supress expception throwing.
|
if (ret_val == 0)
|
||||||
// Error code of permission() calls is ignored on purpose - if they fail,
|
{
|
||||||
// the copy_file() function will fail appropriately and we don't want the permission()
|
rename_file(to_temp, to);
|
||||||
// calls to cause needless failures on permissionless filesystems (ie. FATs on SD cards etc.)
|
}
|
||||||
// or when the target file doesn't exist.
|
}
|
||||||
boost::system::error_code ec;
|
return ret_val;
|
||||||
boost::filesystem::permissions(target, perms, ec);
|
|
||||||
boost::filesystem::copy_file(source, target, boost::filesystem::copy_option::overwrite_if_exists, ec);
|
|
||||||
if (ec) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
boost::filesystem::permissions(target, perms, ec);
|
|
||||||
return (with_check ? check_copy(from, to) : 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int check_copy(const std::string &origin, const std::string ©)
|
int check_copy(const std::string &origin, const std::string ©)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue