Support fchmod and include the correct portability headers for FileUtil
authorChristopher Dykes <cdykes@fb.com>
Thu, 22 Dec 2016 03:38:12 +0000 (19:38 -0800)
committerFacebook Github Bot <facebook-github-bot@users.noreply.github.com>
Thu, 22 Dec 2016 03:47:57 +0000 (19:47 -0800)
Summary: `FileUtil.cpp` uses `fchmod`, which Windows doesn't have, so implement it and also include the correct portability headers for the use of `mkstemp` and now `fchmod` as well.

Reviewed By: yfeldblum

Differential Revision: D4360650

fbshipit-source-id: 300163689c54574548e7bf274a56264714d216ed

folly/FileUtil.cpp
folly/portability/SysStat.cpp
folly/portability/SysStat.h

index 0ec03b3cc6bfb4bb036c36c88ceecd385b860709..c4960aded164ccb94124a5cf04956622b82439a7 100644 (file)
@@ -22,7 +22,9 @@
 #include <folly/detail/FileUtilDetail.h>
 #include <folly/portability/Fcntl.h>
 #include <folly/portability/Sockets.h>
+#include <folly/portability/Stdlib.h>
 #include <folly/portability/SysFile.h>
+#include <folly/portability/SysStat.h>
 
 namespace folly {
 
index 1eecdc1603b304e939e80220ba0a29d3413fac8a..c98dafbae69a8966fa6b8aca4b884b8081107e05 100755 (executable)
 extern "C" {
 int chmod(char const* fn, int am) { return _chmod(fn, am); }
 
+int fchmod(int fd, mode_t mode) {
+  HANDLE h = (HANDLE)_get_osfhandle(fd);
+  if (h == INVALID_HANDLE_VALUE) {
+    return -1;
+  }
+
+  FILE_ATTRIBUTE_TAG_INFO attr{};
+  if (!GetFileInformationByHandleEx(
+          h, FileAttributeTagInfo, &attr, sizeof(attr))) {
+    return -1;
+  }
+
+  if (mode & _S_IWRITE) {
+    attr.FileAttributes &= ~FILE_ATTRIBUTE_READONLY;
+  } else {
+    attr.FileAttributes |= FILE_ATTRIBUTE_READONLY;
+  }
+
+  if (!SetFileInformationByHandle(
+          h, FileAttributeTagInfo, &attr, sizeof(attr))) {
+    return -1;
+  }
+
+  return 0;
+}
+
 // Just return the result of a normal stat for now
 int lstat(const char* path, struct stat* st) { return stat(path, st); }
 
index a98cc6a94f2178bac341132530be2b6bf153b239..e7367778d3ebefeae120740607f671da8f8ea259 100755 (executable)
@@ -19,6 +19,8 @@
 #include <sys/stat.h>
 
 #ifdef _WIN32
+#include <folly/portability/SysTypes.h>
+
 // Windows gives weird names to these.
 #define S_IXUSR 0
 #define S_IWUSR _S_IWRITE
@@ -38,6 +40,7 @@
 
 extern "C" {
 int chmod(char const* fn, int am);
+int fchmod(int fd, mode_t mode);
 int lstat(const char* path, struct stat* st);
 int mkdir(const char* fn, int mode);
 int umask(int md);