|  | /** | 
|  | * This file has no copyright assigned and is placed in the Public Domain. | 
|  | * This file is part of the w64 mingw-runtime package. | 
|  | * No warranty is given; refer to the file DISCLAIMER.PD within this package. | 
|  | */ | 
|  |  | 
|  | #include <_mingw_unicode.h> | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | #ifdef WANT_GETDISKFREESPACEEX_WRAPPER | 
|  |  | 
|  | #undef GetDiskFreeSpaceEx | 
|  | #define GetDiskFreeSpaceEx _GetDiskFreeSpaceEx | 
|  |  | 
|  | extern WINBOOL (CALLBACK *GetDiskFreeSpaceEx)(LPCTSTR,PULARGE_INTEGER,PULARGE_INTEGER,PULARGE_INTEGER); | 
|  |  | 
|  | #ifdef COMPILE_NEWAPIS_STUBS | 
|  | static WINBOOL WINAPI Emulate_GetDiskFreeSpaceEx(LPCTSTR ptszRoot,PULARGE_INTEGER pliQuota,PULARGE_INTEGER pliTotal,PULARGE_INTEGER pliFree) { | 
|  | DWORD dwSecPerClus,dwBytesPerSec,dwFreeClus,dwTotalClus; | 
|  | WINBOOL fRc; | 
|  | fRc = GetDiskFreeSpace(ptszRoot,&dwSecPerClus,&dwBytesPerSec,&dwFreeClus,&dwTotalClus); | 
|  | if(fRc) { | 
|  | DWORD dwBytesPerClus = dwSecPerClus *dwBytesPerSec; | 
|  | *(__int64 *)pliQuota = Int32x32To64(dwBytesPerClus,dwFreeClus); | 
|  | if(pliFree) { | 
|  | *pliFree = *pliQuota; | 
|  | } | 
|  | *(__int64 *)pliTotal = Int32x32To64(dwBytesPerClus,dwTotalClus); | 
|  | } | 
|  | return fRc; | 
|  | } | 
|  |  | 
|  | static WINBOOL WINAPI Probe_GetDiskFreeSpaceEx(LPCTSTR ptszRoot,PULARGE_INTEGER pliQuota,PULARGE_INTEGER pliTotal,PULARGE_INTEGER pliFree) { | 
|  | HINSTANCE hinst; | 
|  | FARPROC fp; | 
|  | WINBOOL fRc; | 
|  | WINBOOL (CALLBACK *RealGetDiskFreeSpaceEx) (LPCTSTR,PULARGE_INTEGER,PULARGE_INTEGER,PULARGE_INTEGER); | 
|  | hinst = GetModuleHandle(TEXT("KERNEL32")); | 
|  | fp = GetProcAddress(hinst,"GetDiskFreeSpaceEx" __MINGW_PROCNAMEEXT_AW); | 
|  | if(fp) { | 
|  | *(FARPROC *)&RealGetDiskFreeSpaceEx = fp; | 
|  | fRc = RealGetDiskFreeSpaceEx(ptszRoot,pliQuota,pliTotal,pliFree); | 
|  | if(fRc || GetLastError()!=ERROR_CALL_NOT_IMPLEMENTED) { | 
|  | GetDiskFreeSpaceEx = RealGetDiskFreeSpaceEx; | 
|  | } else { | 
|  | GetDiskFreeSpaceEx = Emulate_GetDiskFreeSpaceEx; | 
|  | fRc = GetDiskFreeSpaceEx(ptszRoot,pliQuota,pliTotal,pliFree); | 
|  | } | 
|  | } else { | 
|  | GetDiskFreeSpaceEx = Emulate_GetDiskFreeSpaceEx; | 
|  | fRc = GetDiskFreeSpaceEx(ptszRoot,pliQuota,pliTotal,pliFree); | 
|  | } | 
|  | return fRc; | 
|  | } | 
|  |  | 
|  | WINBOOL (CALLBACK *GetDiskFreeSpaceEx) (LPCTSTR,PULARGE_INTEGER,PULARGE_INTEGER,PULARGE_INTEGER) = Probe_GetDiskFreeSpaceEx; | 
|  | #endif | 
|  | #endif | 
|  |  | 
|  | #ifdef WANT_GETLONGPATHNAME_WRAPPER | 
|  | #include <shlobj.h> | 
|  |  | 
|  | #undef GetLongPathName | 
|  | #define GetLongPathName _GetLongPathName | 
|  |  | 
|  | extern DWORD (CALLBACK *GetLongPathName)(LPCTSTR,LPTSTR,DWORD); | 
|  |  | 
|  | #ifdef COMPILE_NEWAPIS_STUBS | 
|  | static DWORD WINAPI Emulate_GetLongPathName(LPCTSTR ptszShort,LPTSTR ptszLong,DWORD ctchBuf) { | 
|  | LPSHELLFOLDER psfDesk; | 
|  | HRESULT hr; | 
|  | LPITEMIDLIST pidl; | 
|  | TCHAR tsz[MAX_PATH]; | 
|  | DWORD dwRc; | 
|  | LPMALLOC pMalloc; | 
|  | if(GetFileAttributes(ptszShort)==0xFFFFFFFF) return 0; | 
|  | dwRc = GetFullPathName(ptszShort,MAX_PATH,tsz,NULL); | 
|  | if(dwRc==0) { | 
|  | } else if(dwRc >= MAX_PATH) { | 
|  | SetLastError(ERROR_BUFFER_OVERFLOW); | 
|  | dwRc = 0; | 
|  | } else { | 
|  | hr = SHGetDesktopFolder(&psfDesk); | 
|  | if(SUCCEEDED(hr)) { | 
|  | ULONG cwchEaten; | 
|  | #if defined(UNICODE) | 
|  | #ifdef __cplusplus | 
|  | hr = psfDesk->ParseDisplayName(NULL,NULL,tsz,&cwchEaten,&pidl,NULL); | 
|  | #else | 
|  | hr = psfDesk->lpVtbl->ParseDisplayName(psfDesk,NULL,NULL,tsz,&cwchEaten,&pidl,NULL); | 
|  | #endif | 
|  | #else | 
|  | WCHAR wsz[MAX_PATH]; | 
|  |  | 
|  | dwRc = MultiByteToWideChar(AreFileApisANSI() ? CP_ACP : CP_OEMCP,0,tsz,-1,wsz,MAX_PATH); | 
|  | if(dwRc==0) { | 
|  | if(GetLastError()==ERROR_INSUFFICIENT_BUFFER) { | 
|  | SetLastError(ERROR_BUFFER_OVERFLOW); | 
|  | } | 
|  | dwRc = 0; | 
|  | } else { | 
|  | #ifdef __cplusplus | 
|  | hr = psfDesk->ParseDisplayName(NULL,NULL,wsz,&cwchEaten,&pidl,NULL); | 
|  | #else | 
|  | hr = psfDesk->lpVtbl->ParseDisplayName(psfDesk,NULL,NULL,wsz,&cwchEaten,&pidl,NULL); | 
|  | #endif | 
|  | #endif | 
|  | if(FAILED(hr)) { | 
|  | if(HRESULT_FACILITY(hr)==FACILITY_WIN32) { | 
|  | SetLastError(HRESULT_CODE(hr)); | 
|  | } else { | 
|  | SetLastError(ERROR_INVALID_DATA); | 
|  | } | 
|  | dwRc = 0; | 
|  | } else { | 
|  | dwRc = SHGetPathFromIDList(pidl,tsz); | 
|  | if(dwRc==0 && tsz[0]) { | 
|  | SetLastError(ERROR_INVALID_DATA); | 
|  | } else { | 
|  | dwRc = lstrlen(tsz); | 
|  | if(dwRc + 1 > ctchBuf) { | 
|  | SetLastError(ERROR_INSUFFICIENT_BUFFER); | 
|  | dwRc = dwRc + 1; | 
|  | } else { | 
|  | lstrcpyn(ptszLong,tsz,ctchBuf); | 
|  | } | 
|  | } | 
|  | if(SUCCEEDED(SHGetMalloc(&pMalloc))) { | 
|  | #ifdef __cplusplus | 
|  | pMalloc->Free(pidl); | 
|  | pMalloc->Release(); | 
|  | #else | 
|  | pMalloc->lpVtbl->Free(pMalloc,pidl); | 
|  | pMalloc->lpVtbl->Release(pMalloc); | 
|  | #endif | 
|  | } | 
|  | } | 
|  | #if !defined(UNICODE) | 
|  | } | 
|  | #endif | 
|  | #ifdef __cplusplus | 
|  | psfDesk->Release(); | 
|  | #else | 
|  | psfDesk->lpVtbl->Release(psfDesk); | 
|  | #endif | 
|  | } | 
|  | } | 
|  | return dwRc; | 
|  | } | 
|  |  | 
|  | static DWORD WINAPI Probe_GetLongPathName(LPCTSTR ptszShort,LPTSTR ptszLong,DWORD ctchBuf) { | 
|  | HINSTANCE hinst; | 
|  | FARPROC fp; | 
|  | DWORD dwRc; | 
|  | DWORD (CALLBACK *RealGetLongPathName)(LPCTSTR,LPTSTR,DWORD); | 
|  | hinst = GetModuleHandle(TEXT("KERNEL32")); | 
|  |  | 
|  | fp = GetProcAddress(hinst,"GetLongPathName" __MINGW_PROCNAMEEXT_AW); | 
|  | if(fp) { | 
|  | *(FARPROC *)&RealGetLongPathName = fp; | 
|  | dwRc = RealGetLongPathName(ptszShort,ptszLong,ctchBuf); | 
|  | if(dwRc || GetLastError()!=ERROR_CALL_NOT_IMPLEMENTED) { | 
|  | GetLongPathName = RealGetLongPathName; | 
|  | } else { | 
|  | GetLongPathName = Emulate_GetLongPathName; | 
|  | dwRc = GetLongPathName(ptszShort,ptszLong,ctchBuf); | 
|  | } | 
|  | } else { | 
|  | GetLongPathName = Emulate_GetLongPathName; | 
|  | dwRc = GetLongPathName(ptszShort,ptszLong,ctchBuf); | 
|  | } | 
|  | return dwRc; | 
|  |  | 
|  | } | 
|  |  | 
|  | DWORD (CALLBACK *GetLongPathName)(LPCTSTR,LPTSTR,DWORD) = Probe_GetLongPathName; | 
|  | #endif | 
|  | #endif | 
|  |  | 
|  | #ifdef WANT_GETFILEATTRIBUTESEX_WRAPPER | 
|  |  | 
|  | #undef GetFileAttributesEx | 
|  | #define GetFileAttributesEx _GetFileAttributesEx | 
|  |  | 
|  | extern WINBOOL (CALLBACK *GetFileAttributesEx) | 
|  | (LPCTSTR,GET_FILEEX_INFO_LEVELS,LPVOID); | 
|  |  | 
|  | #ifdef COMPILE_NEWAPIS_STUBS | 
|  |  | 
|  | static WINBOOL WINAPI Emulate_GetFileAttributesEx(LPCTSTR ptszFile,GET_FILEEX_INFO_LEVELS level,LPVOID pv) { | 
|  | WINBOOL fRc; | 
|  | if(level==GetFileExInfoStandard) { | 
|  | if(GetFileAttributes(ptszFile)!=0xFFFFFFFF) { | 
|  | HANDLE hfind; | 
|  | WIN32_FIND_DATA wfd; | 
|  | hfind = FindFirstFile(ptszFile,&wfd); | 
|  | if(hfind!=INVALID_HANDLE_VALUE) { | 
|  | LPWIN32_FILE_ATTRIBUTE_DATA pfad = pv; | 
|  | FindClose(hfind); | 
|  | pfad->dwFileAttributes = wfd.dwFileAttributes; | 
|  | pfad->ftCreationTime = wfd.ftCreationTime; | 
|  | pfad->ftLastAccessTime = wfd.ftLastAccessTime; | 
|  | pfad->ftLastWriteTime = wfd.ftLastWriteTime; | 
|  | pfad->nFileSizeHigh = wfd.nFileSizeHigh; | 
|  | pfad->nFileSizeLow = wfd.nFileSizeLow; | 
|  |  | 
|  | fRc = TRUE; | 
|  | } else { | 
|  | fRc = FALSE; | 
|  | } | 
|  | } else { | 
|  | fRc = FALSE; | 
|  | } | 
|  | } else { | 
|  | SetLastError(ERROR_INVALID_PARAMETER); | 
|  | fRc = FALSE; | 
|  | } | 
|  | return fRc; | 
|  | } | 
|  |  | 
|  | static WINBOOL WINAPI Probe_GetFileAttributesEx(LPCTSTR ptszFile,GET_FILEEX_INFO_LEVELS level,LPVOID pv) { | 
|  | HINSTANCE hinst; | 
|  | FARPROC fp; | 
|  | WINBOOL fRc; | 
|  | WINBOOL (CALLBACK *RealGetFileAttributesEx)(LPCTSTR,GET_FILEEX_INFO_LEVELS,LPVOID); | 
|  | hinst = GetModuleHandle(TEXT("KERNEL32")); | 
|  | fp = GetProcAddress(hinst,"GetFileAttributesEx" __MINGW_PROCNAMEEXT_AW); | 
|  | if(fp) { | 
|  | *(FARPROC *)&RealGetFileAttributesEx = fp; | 
|  | fRc = RealGetFileAttributesEx(ptszFile,level,pv); | 
|  | if(fRc || GetLastError()!=ERROR_CALL_NOT_IMPLEMENTED) { | 
|  | GetFileAttributesEx = RealGetFileAttributesEx; | 
|  | } else { | 
|  | GetFileAttributesEx = Emulate_GetFileAttributesEx; | 
|  | fRc = GetFileAttributesEx(ptszFile,level,pv); | 
|  | } | 
|  | } else { | 
|  | GetFileAttributesEx = Emulate_GetFileAttributesEx; | 
|  | fRc = GetFileAttributesEx(ptszFile,level,pv); | 
|  | } | 
|  | return fRc; | 
|  | } | 
|  |  | 
|  | WINBOOL (CALLBACK *GetFileAttributesEx)(LPCTSTR,GET_FILEEX_INFO_LEVELS,LPVOID) = Probe_GetFileAttributesEx; | 
|  | #endif | 
|  | #endif | 
|  |  | 
|  | #ifdef WANT_ISDEBUGGERPRESENT_WRAPPER | 
|  | #define IsDebuggerPresent _IsDebuggerPresent | 
|  |  | 
|  | extern WINBOOL (CALLBACK *IsDebuggerPresent)(VOID); | 
|  |  | 
|  | #ifdef COMPILE_NEWAPIS_STUBS | 
|  | static WINBOOL WINAPI Emulate_IsDebuggerPresent(VOID) { return FALSE; } | 
|  | static WINBOOL WINAPI Probe_IsDebuggerPresent(VOID) { | 
|  | HINSTANCE hinst; | 
|  | FARPROC fp; | 
|  | WINBOOL (CALLBACK *RealIsDebuggerPresent)(VOID); | 
|  | hinst = GetModuleHandle(TEXT("KERNEL32")); | 
|  | fp = GetProcAddress(hinst,"IsDebuggerPresent"); | 
|  | if(fp) { | 
|  | *(FARPROC *)&IsDebuggerPresent = fp; | 
|  | } else { | 
|  | IsDebuggerPresent = Emulate_IsDebuggerPresent; | 
|  | } | 
|  | return IsDebuggerPresent(); | 
|  | } | 
|  |  | 
|  | WINBOOL (CALLBACK *IsDebuggerPresent)(VOID) = Probe_IsDebuggerPresent; | 
|  | #endif | 
|  | #endif | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | } | 
|  | #endif |