diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-05 21:01:08 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-05 21:01:08 +0000 |
commit | c9d2e5b8ca06bdb9af8338ec7dde5eafad40d9f0 (patch) | |
tree | a5d007b8b2b1a7b425b799c0ec49a1f3c60e2456 /llvm/lib/Support/LockFileManager.cpp | |
parent | 10357900342fe7509f28f95edf3e01119227d311 (diff) | |
download | bcm5719-llvm-c9d2e5b8ca06bdb9af8338ec7dde5eafad40d9f0.tar.gz bcm5719-llvm-c9d2e5b8ca06bdb9af8338ec7dde5eafad40d9f0.zip |
Add a createUniqueFile function and switch llvm's users of unique_file.
This function is complementary to createTemporaryFile. It handles the case were
the unique file is *not* temporary: we will rename it in the end. Since we
will rename it, the file has to be in the same filesystem as the final
destination and we don't prepend the system temporary directory.
This has a small semantic difference from unique_file: the default mode is 0666.
This matches the behavior of most unix tools. For example, with this change
lld now produces files with the same permissions as ld. I will add a test
of this change when I port clang over to createUniqueFile (next commit).
llvm-svn: 185726
Diffstat (limited to 'llvm/lib/Support/LockFileManager.cpp')
-rw-r--r-- | llvm/lib/Support/LockFileManager.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/llvm/lib/Support/LockFileManager.cpp b/llvm/lib/Support/LockFileManager.cpp index 2917e273bce..21c4d4070d2 100644 --- a/llvm/lib/Support/LockFileManager.cpp +++ b/llvm/lib/Support/LockFileManager.cpp @@ -78,10 +78,9 @@ LockFileManager::LockFileManager(StringRef FileName) UniqueLockFileName += "-%%%%%%%%"; int UniqueLockFileID; if (error_code EC - = sys::fs::unique_file(UniqueLockFileName.str(), - UniqueLockFileID, - UniqueLockFileName, - /*makeAbsolute=*/false)) { + = sys::fs::createUniqueFile(UniqueLockFileName.str(), + UniqueLockFileID, + UniqueLockFileName)) { Error = EC; return; } |