aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-06-26 17:28:04 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-06-26 17:28:04 +0000
commit97c2a0a1100fecb3c2dcd4d582eeaa8fe2ffb335 (patch)
tree72ad56f6a78d29c8ca25a5d53fa684953a1dd68d
parente26fa2dd73c035726331246e1c397617f9634f12 (diff)
downloadexternal_llvm-97c2a0a1100fecb3c2dcd4d582eeaa8fe2ffb335.zip
external_llvm-97c2a0a1100fecb3c2dcd4d582eeaa8fe2ffb335.tar.gz
external_llvm-97c2a0a1100fecb3c2dcd4d582eeaa8fe2ffb335.tar.bz2
Use enums instead of raw octal values.
Patch by 罗勇刚(Yonggang Luo). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184971 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/Support/FileSystem.h9
-rw-r--r--lib/Support/Unix/PathV2.inc1
-rw-r--r--tools/llvm-ar/ArchiveWriter.cpp2
3 files changed, 8 insertions, 4 deletions
diff --git a/include/llvm/Support/FileSystem.h b/include/llvm/Support/FileSystem.h
index 558145c..b721927 100644
--- a/include/llvm/Support/FileSystem.h
+++ b/include/llvm/Support/FileSystem.h
@@ -111,6 +111,9 @@ enum perms {
others_write = 02,
others_exe = 01,
others_all = others_read | others_write | others_exe,
+ all_read = owner_read | group_read | others_read,
+ all_write = owner_write | group_write | others_write,
+ all_exe = owner_exe | group_exe | others_exe,
all_all = owner_all | group_all | others_all,
set_uid_on_exe = 04000,
set_gid_on_exe = 02000,
@@ -559,15 +562,17 @@ error_code status_known(const Twine &path, bool &result);
/// @param result_path Set to the opened file's absolute path.
/// @param makeAbsolute If true and \a model is not an absolute path, a temp
/// directory will be prepended.
+/// @param mode Set to the file open mode; since this is most often used for
+/// temporary files, mode defaults to owner_read | owner_write.
/// @returns errc::success if result_{fd,path} have been successfully set,
/// otherwise a platform specific error_code.
error_code unique_file(const Twine &model, int &result_fd,
SmallVectorImpl<char> &result_path,
- bool makeAbsolute = true, unsigned mode = 0600);
+ bool makeAbsolute = true, unsigned mode = owner_read | owner_write);
/// @brief Simpler version for clients that don't want an open file.
error_code unique_file(const Twine &Model, SmallVectorImpl<char> &ResultPath,
- bool MakeAbsolute = true, unsigned Mode = 0600);
+ bool MakeAbsolute = true, unsigned Mode = owner_read | owner_write);
/// @brief Canonicalize path.
///
diff --git a/lib/Support/Unix/PathV2.inc b/lib/Support/Unix/PathV2.inc
index 29a89b0..91efcd8 100644
--- a/lib/Support/Unix/PathV2.inc
+++ b/lib/Support/Unix/PathV2.inc
@@ -564,7 +564,6 @@ error_code setLastModificationAndAccessTime(int FD, TimeValue Time) {
return error_code::success();
}
-// Since this is most often used for temporary files, mode defaults to 0600.
error_code unique_file(const Twine &model, int &result_fd,
SmallVectorImpl<char> &result_path,
bool makeAbsolute, unsigned mode) {
diff --git a/tools/llvm-ar/ArchiveWriter.cpp b/tools/llvm-ar/ArchiveWriter.cpp
index 8f010ad..7dad7e0 100644
--- a/tools/llvm-ar/ArchiveWriter.cpp
+++ b/tools/llvm-ar/ArchiveWriter.cpp
@@ -268,7 +268,7 @@ bool Archive::writeToDisk(bool TruncateNames, std::string *ErrMsg) {
int TmpArchiveFD;
SmallString<128> TmpArchive;
error_code EC = sys::fs::unique_file("temp-archive-%%%%%%%.a", TmpArchiveFD,
- TmpArchive, true, 0666);
+ TmpArchive, true, sys::fs::all_read | sys::fs::all_write);
if (EC)
return true;