diff options
author | John Criswell <criswell@uiuc.edu> | 2003-09-02 21:09:30 +0000 |
---|---|---|
committer | John Criswell <criswell@uiuc.edu> | 2003-09-02 21:09:30 +0000 |
commit | 66622be46acfdebdfb82f1f6b988912ec8b61754 (patch) | |
tree | d7f96d414c70c1c75fdea3792220375a679ef6b6 /support/lib/Support/FileUtilities.cpp | |
parent | 9adeccc552d6f28bdc503a8c1ffe13ea6ea6d73d (diff) |
Added the MakeFileReadable() method.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8327 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'support/lib/Support/FileUtilities.cpp')
-rw-r--r-- | support/lib/Support/FileUtilities.cpp | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/support/lib/Support/FileUtilities.cpp b/support/lib/Support/FileUtilities.cpp index 16c41bc7b9..7c8142a4a6 100644 --- a/support/lib/Support/FileUtilities.cpp +++ b/support/lib/Support/FileUtilities.cpp @@ -147,3 +147,57 @@ MakeFileExecutable (const std::string & Filename) return true; } +/// +/// Method: MakeFileReadable () +/// +/// Description: +/// This method makes the specified filename readable by giving it +/// read permission. It respects the umask value of the process, and it +/// does not enable any unnecessary access bits. +/// +/// Algorithm: +/// o Get file's current permissions. +/// o Get the process's current umask. +/// o Take the set of all read bits and disable those found in the umask. +/// o Add the remaining permissions to the file's permissions. +/// +bool +MakeFileReadable (const std::string & Filename) +{ + // Permissions masking value of the user + mode_t mask; + + // Permissions currently enabled on the file + struct stat fstat; + + // + // Grab the umask value from the operating system. We want to use it when + // changing the file's permissions. + // + // Note: + // Umask() is one of those annoying system calls. You have to call it + // to get the current value and then set it back. + // + mask = umask (0x777); + umask (mask); + + // + // Go fetch the file's current permission bits. We want to *add* execute + // access to the file. + // + if ((stat (Filename.c_str(), &fstat)) == -1) + { + return false; + } + + // + // Make the file executable... + // + if ((chmod(Filename.c_str(), (fstat.st_mode | (0444 & ~mask)))) == -1) + { + return false; + } + + return true; +} + |