svn commit: r236260 - in head/contrib/llvm: include/llvm/Support
lib/Support/Unix lib/Support/Windows tools/clang/lib/Frontend
Dimitry Andric
dim at FreeBSD.org
Tue May 29 21:59:10 UTC 2012
Author: dim
Date: Tue May 29 21:59:09 2012
New Revision: 236260
URL: http://svn.freebsd.org/changeset/base/236260
Log:
Pull in r156591 from upstream llvm trunk:
Allow unique_file to take a mode for file permissions, but default
to user only read/write.
and r156592 from upstream clang trunk:
For final output files create them with mode 0664 to match other
compilers and expected defaults.
This should fix clang creating files with mode 0600.
Reported by: James <james at hicag.org>
MFC after: 3 days
Modified:
head/contrib/llvm/include/llvm/Support/FileSystem.h
head/contrib/llvm/lib/Support/Unix/PathV2.inc
head/contrib/llvm/lib/Support/Windows/PathV2.inc
head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp
Modified: head/contrib/llvm/include/llvm/Support/FileSystem.h
==============================================================================
--- head/contrib/llvm/include/llvm/Support/FileSystem.h Tue May 29 21:34:09 2012 (r236259)
+++ head/contrib/llvm/include/llvm/Support/FileSystem.h Tue May 29 21:59:09 2012 (r236260)
@@ -422,8 +422,8 @@ error_code status_known(const Twine &pat
/// @results 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);
+ SmallVectorImpl<char> &result_path,
+ bool makeAbsolute = true, unsigned mode = 0600);
/// @brief Canonicalize path.
///
Modified: head/contrib/llvm/lib/Support/Unix/PathV2.inc
==============================================================================
--- head/contrib/llvm/lib/Support/Unix/PathV2.inc Tue May 29 21:34:09 2012 (r236259)
+++ head/contrib/llvm/lib/Support/Unix/PathV2.inc Tue May 29 21:59:09 2012 (r236260)
@@ -346,9 +346,10 @@ error_code status(const Twine &path, fil
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) {
+ SmallVectorImpl<char> &result_path,
+ bool makeAbsolute, unsigned mode) {
SmallString<128> Model;
model.toVector(Model);
// Null terminate.
@@ -395,7 +396,7 @@ retry_random_path:
// Try to open + create the file.
rety_open_create:
- int RandomFD = ::open(RandomPath.c_str(), O_RDWR | O_CREAT | O_EXCL, 0600);
+ int RandomFD = ::open(RandomPath.c_str(), O_RDWR | O_CREAT | O_EXCL, mode);
if (RandomFD == -1) {
// If the file existed, try again, otherwise, error.
if (errno == errc::file_exists)
Modified: head/contrib/llvm/lib/Support/Windows/PathV2.inc
==============================================================================
--- head/contrib/llvm/lib/Support/Windows/PathV2.inc Tue May 29 21:34:09 2012 (r236259)
+++ head/contrib/llvm/lib/Support/Windows/PathV2.inc Tue May 29 21:59:09 2012 (r236260)
@@ -487,9 +487,11 @@ handle_status_error:
return error_code::success();
}
+// FIXME: mode should be used here and default to user r/w only,
+// it currently comes in as a UNIX mode.
error_code unique_file(const Twine &model, int &result_fd,
- SmallVectorImpl<char> &result_path,
- bool makeAbsolute) {
+ SmallVectorImpl<char> &result_path,
+ bool makeAbsolute, unsigned mode) {
// Use result_path as temp storage.
result_path.set_size(0);
StringRef m = model.toStringRef(result_path);
Modified: head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp
==============================================================================
--- head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp Tue May 29 21:34:09 2012 (r236259)
+++ head/contrib/llvm/tools/clang/lib/Frontend/CompilerInstance.cpp Tue May 29 21:59:09 2012 (r236260)
@@ -560,7 +560,8 @@ CompilerInstance::createOutputFile(Strin
TempPath += "-%%%%%%%%";
int fd;
if (llvm::sys::fs::unique_file(TempPath.str(), fd, TempPath,
- /*makeAbsolute=*/false) == llvm::errc::success) {
+ /*makeAbsolute=*/false, 0664)
+ == llvm::errc::success) {
OS.reset(new llvm::raw_fd_ostream(fd, /*shouldClose=*/true));
OSFile = TempFile = TempPath.str();
}
More information about the svn-src-head
mailing list