summaryrefslogtreecommitdiff
path: root/support/lib/Support
diff options
context:
space:
mode:
authorJohn Criswell <criswell@uiuc.edu>2003-09-02 20:30:16 +0000
committerJohn Criswell <criswell@uiuc.edu>2003-09-02 20:30:16 +0000
commit9adeccc552d6f28bdc503a8c1ffe13ea6ea6d73d (patch)
tree2f18b2aebd77ff7f8b7cdbe31dd0e011106c2ee4 /support/lib/Support
parentd35b5b542da2f4855856495fc28ddca8d9092979 (diff)
downloadllvm-9adeccc552d6f28bdc503a8c1ffe13ea6ea6d73d.tar.gz
llvm-9adeccc552d6f28bdc503a8c1ffe13ea6ea6d73d.tar.bz2
llvm-9adeccc552d6f28bdc503a8c1ffe13ea6ea6d73d.tar.xz
Added a description of the algorithm.
Return failure if the chmod() fails. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8326 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'support/lib/Support')
-rw-r--r--support/lib/Support/FileUtilities.cpp21
1 files changed, 14 insertions, 7 deletions
diff --git a/support/lib/Support/FileUtilities.cpp b/support/lib/Support/FileUtilities.cpp
index 01d7ca2126..16c41bc7b9 100644
--- a/support/lib/Support/FileUtilities.cpp
+++ b/support/lib/Support/FileUtilities.cpp
@@ -98,12 +98,14 @@ std::string getUniqueFilename(const std::string &FilenameBase) {
///
/// Description:
/// This method makes the specified filename executable by giving it
-/// execute permission.
+/// execute permission. It respects the umask value of the process, and it
+/// does not enable any unnecessary access bits.
///
-/// For the UNIX version of this method, we turn on all of the read and
-/// execute bits and then turn off anything specified in the umask. This
-/// should help ensure that access to the file remains at the level that
-/// the user desires.
+/// Algorithm:
+/// o Get file's current permissions.
+/// o Get the process's current umask.
+/// o Take the set of all execute bits and disable those found in the umask.
+/// o Add the remaining permissions to the file's permissions.
///
bool
MakeFileExecutable (const std::string & Filename)
@@ -134,8 +136,13 @@ MakeFileExecutable (const std::string & Filename)
return false;
}
- // Make the script executable...
- chmod(Filename.c_str(), (fstat.st_mode | (0111 & ~mask)));
+ //
+ // Make the file executable...
+ //
+ if ((chmod(Filename.c_str(), (fstat.st_mode | (0111 & ~mask)))) == -1)
+ {
+ return false;
+ }
return true;
}