mirror of
https://github.com/opnsense/src.git
synced 2026-05-28 04:12:45 -04:00
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@hicag.org> MFC after: 3 days
This commit is contained in:
parent
baa749209e
commit
96ccbf68a6
4 changed files with 12 additions and 8 deletions
|
|
@ -422,8 +422,8 @@ error_code status_known(const Twine &path, bool &result);
|
|||
/// @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.
|
||||
///
|
||||
|
|
|
|||
|
|
@ -346,9 +346,10 @@ error_code status(const Twine &path, file_status &result) {
|
|||
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)
|
||||
|
|
|
|||
|
|
@ -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);
|
||||
|
|
|
|||
|
|
@ -560,7 +560,8 @@ CompilerInstance::createOutputFile(StringRef OutputPath,
|
|||
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();
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue