aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/port/win32stat.c38
1 files changed, 22 insertions, 16 deletions
diff --git a/src/port/win32stat.c b/src/port/win32stat.c
index a70df3a5900..c111f0ef353 100644
--- a/src/port/win32stat.c
+++ b/src/port/win32stat.c
@@ -40,14 +40,12 @@ typedef struct _FILE_STANDARD_INFORMATION
#endif /* !defined(__MINGW32__) &&
* !defined(__MINGW64__) */
-typedef NTSTATUS(NTAPI * PFN_NTQUERYINFORMATIONFILE)
-(
- IN HANDLE FileHandle,
- OUT PIO_STATUS_BLOCK IoStatusBlock,
- OUT PVOID FileInformation,
- IN ULONG Length,
- IN FILE_INFORMATION_CLASS FileInformationClass
-);
+typedef NTSTATUS (NTAPI * PFN_NTQUERYINFORMATIONFILE)
+ (IN HANDLE FileHandle,
+ OUT PIO_STATUS_BLOCK IoStatusBlock,
+ OUT PVOID FileInformation,
+ IN ULONG Length,
+ IN FILE_INFORMATION_CLASS FileInformationClass);
static PFN_NTQUERYINFORMATIONFILE _NtQueryInformationFile = NULL;
@@ -101,8 +99,8 @@ fileattr_to_unixmode(int attr)
uxmode |= (unsigned short) ((attr & FILE_ATTRIBUTE_DIRECTORY) ?
(_S_IFDIR) : (_S_IFREG));
- uxmode |= (unsigned short) (attr & FILE_ATTRIBUTE_READONLY) ?
- (_S_IREAD) : (_S_IREAD | _S_IWRITE);
+ uxmode |= (unsigned short) ((attr & FILE_ATTRIBUTE_READONLY) ?
+ (_S_IREAD) : (_S_IREAD | _S_IWRITE));
/* there is no need to simulate _S_IEXEC using CMD's PATHEXT extensions */
uxmode |= _S_IEXEC;
@@ -149,8 +147,8 @@ fileinfo_to_stat(HANDLE hFile, struct stat *buf)
buf->st_mode = fileattr_to_unixmode(fiData.dwFileAttributes);
buf->st_nlink = fiData.nNumberOfLinks;
- buf->st_size = (((uint64) fiData.nFileSizeHigh) << 32) |
- (uint64) fiData.nFileSizeLow;
+ buf->st_size = ((((uint64) fiData.nFileSizeHigh) << 32) |
+ fiData.nFileSizeLowi);
return 0;
}
@@ -220,8 +218,10 @@ _pgstat64(const char *name, struct stat *buf)
LoadNtdll();
if (ntdll == NULL)
{
- _dosmaperr(GetLastError());
+ DWORD err = GetLastError();
+
CloseHandle(hFile);
+ _dosmaperr(err);
return -1;
}
@@ -229,8 +229,10 @@ _pgstat64(const char *name, struct stat *buf)
GetProcAddress(ntdll, "NtQueryInformationFile");
if (_NtQueryInformationFile == NULL)
{
- _dosmaperr(GetLastError());
+ DWORD err = GetLastError();
+
CloseHandle(hFile);
+ _dosmaperr(err);
return -1;
}
}
@@ -239,16 +241,20 @@ _pgstat64(const char *name, struct stat *buf)
sizeof(standardInfo),
FileStandardInformation)))
{
- _dosmaperr(GetLastError());
+ DWORD err = GetLastError();
+
CloseHandle(hFile);
+ _dosmaperr(err);
return -1;
}
#else
if (!GetFileInformationByHandleEx(hFile, FileStandardInfo, &standardInfo,
sizeof(standardInfo)))
{
- _dosmaperr(GetLastError());
+ DWORD err = GetLastError();
+
CloseHandle(hFile);
+ _dosmaperr(err);
return -1;
}
#endif /* _WIN32_WINNT < 0x0600 */