req->errorno = 0;
}
-/* this is where the CRT stores the current umask */
-extern int _umaskval;
void fs__open(uv_fs_t* req, const char* path, int flags, int mode) {
DWORD access;
DWORD disposition;
DWORD attributes;
HANDLE file;
- int result;
+ int result, current_umask;
+
+ /* Obtain the active umask. umask() never fails and returns the previous */
+ /* umask. */
+ current_umask = umask(0);
+ umask(current_umask);
/* convert flags and mode to CreateFile parameters */
switch (flags & (_O_RDONLY | _O_WRONLY | _O_RDWR)) {
attributes = FILE_ATTRIBUTE_NORMAL;
if (flags & _O_CREAT) {
- if (!((mode & ~_umaskval) & _S_IWRITE)) {
+ if (!((mode & ~current_umask) & _S_IWRITE)) {
attributes |= FILE_ATTRIBUTE_READONLY;
}
}
# define FILE_WRITE_ACCESS 0x0002
#endif
+#ifndef CTL_CODE
+# define CTL_CODE(device_type, function, method, access) \
+ (((device_type) << 16) | ((access) << 14) | ((function) << 2) | (method))
+#endif
+
#ifndef FSCTL_SET_REPARSE_POINT
# define FSCTL_SET_REPARSE_POINT CTL_CODE(FILE_DEVICE_FILE_SYSTEM, \
41, \
ASSERT(r == 0);
#ifdef _WIN32
if (req.result == -1) {
- if (req.errorno == ENOTSUP) {
+ if (req.errorno == ENOSYS) {
/*
* Windows doesn't support symlinks on older versions.
* We just pass the test and bail out early if we get ENOTSUP.