aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-07-17 03:33:41 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-07-17 03:33:41 +0000
commitf33cab4898c1b31cab6d26dcd2444a2b5b12a4e5 (patch)
tree80f511e79a9c6136ee3c5544cab3645f3d4db10d
parent8de25f031d8a8c63e0107f7fd0ac4af6b8ab600c (diff)
downloadexternal_llvm-f33cab4898c1b31cab6d26dcd2444a2b5b12a4e5.zip
external_llvm-f33cab4898c1b31cab6d26dcd2444a2b5b12a4e5.tar.gz
external_llvm-f33cab4898c1b31cab6d26dcd2444a2b5b12a4e5.tar.bz2
Don't fallback to copy + delete in rename.
Rename's documentation says "Files are renamed as if by POSIX rename()". and it is used for atomically updating output files from a temporary. Having rename fallback to a non atomic copy has the potential to hide bugs, like using a temporary file in /tmp instead of a unique name next to the final destination. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186483 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Support/Unix/Path.inc13
1 files changed, 2 insertions, 11 deletions
diff --git a/lib/Support/Unix/Path.inc b/lib/Support/Unix/Path.inc
index 9795b6e..0c1623a 100644
--- a/lib/Support/Unix/Path.inc
+++ b/lib/Support/Unix/Path.inc
@@ -456,17 +456,8 @@ error_code rename(const Twine &from, const Twine &to) {
StringRef f = from.toNullTerminatedStringRef(from_storage);
StringRef t = to.toNullTerminatedStringRef(to_storage);
- if (::rename(f.begin(), t.begin()) == -1) {
- // If it's a cross device link, copy then delete, otherwise return the error
- if (errno == EXDEV) {
- if (error_code ec = copy_file(from, to, copy_option::overwrite_if_exists))
- return ec;
- bool Existed;
- if (error_code ec = remove(from, Existed))
- return ec;
- } else
- return error_code(errno, system_category());
- }
+ if (::rename(f.begin(), t.begin()) == -1)
+ return error_code(errno, system_category());
return error_code::success();
}