-
-
Notifications
You must be signed in to change notification settings - Fork 30.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
gh-99726: Improves correctness of stat results for Windows, and uses …
…faster API when available (GH-102149) This deprecates `st_ctime` fields on Windows, with the intent to change them to contain the correct value in 3.14. For now, they should keep returning the creation time as they always have.
- Loading branch information
Showing
10 changed files
with
446 additions
and
82 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
#ifndef Py_INTERNAL_FILEUTILS_WINDOWS_H | ||
#define Py_INTERNAL_FILEUTILS_WINDOWS_H | ||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
#ifndef Py_BUILD_CORE | ||
# error "Py_BUILD_CORE must be defined to include this header" | ||
#endif | ||
|
||
#ifdef MS_WINDOWS | ||
|
||
#if !defined(NTDDI_WIN10_NI) || !(NTDDI_VERSION >= NTDDI_WIN10_NI) | ||
typedef struct _FILE_STAT_BASIC_INFORMATION { | ||
LARGE_INTEGER FileId; | ||
LARGE_INTEGER CreationTime; | ||
LARGE_INTEGER LastAccessTime; | ||
LARGE_INTEGER LastWriteTime; | ||
LARGE_INTEGER ChangeTime; | ||
LARGE_INTEGER AllocationSize; | ||
LARGE_INTEGER EndOfFile; | ||
ULONG FileAttributes; | ||
ULONG ReparseTag; | ||
ULONG NumberOfLinks; | ||
ULONG DeviceType; | ||
ULONG DeviceCharacteristics; | ||
ULONG Reserved; | ||
FILE_ID_128 FileId128; | ||
LARGE_INTEGER VolumeSerialNumber; | ||
} FILE_STAT_BASIC_INFORMATION; | ||
|
||
typedef enum _FILE_INFO_BY_NAME_CLASS { | ||
FileStatByNameInfo, | ||
FileStatLxByNameInfo, | ||
FileCaseSensitiveByNameInfo, | ||
FileStatBasicByNameInfo, | ||
MaximumFileInfoByNameClass | ||
} FILE_INFO_BY_NAME_CLASS; | ||
#endif | ||
|
||
typedef BOOL (WINAPI *PGetFileInformationByName)( | ||
PCWSTR FileName, | ||
FILE_INFO_BY_NAME_CLASS FileInformationClass, | ||
PVOID FileInfoBuffer, | ||
ULONG FileInfoBufferSize | ||
); | ||
|
||
static inline BOOL _Py_GetFileInformationByName( | ||
PCWSTR FileName, | ||
FILE_INFO_BY_NAME_CLASS FileInformationClass, | ||
PVOID FileInfoBuffer, | ||
ULONG FileInfoBufferSize | ||
) { | ||
static PGetFileInformationByName GetFileInformationByName = NULL; | ||
static int GetFileInformationByName_init = -1; | ||
|
||
if (GetFileInformationByName_init < 0) { | ||
HMODULE hMod = LoadLibraryW(L"api-ms-win-core-file-l2-1-4"); | ||
GetFileInformationByName_init = 0; | ||
if (hMod) { | ||
GetFileInformationByName = (PGetFileInformationByName)GetProcAddress( | ||
hMod, "GetFileInformationByName"); | ||
if (GetFileInformationByName) { | ||
GetFileInformationByName_init = 1; | ||
} else { | ||
FreeLibrary(hMod); | ||
} | ||
} | ||
} | ||
|
||
if (GetFileInformationByName_init <= 0) { | ||
SetLastError(ERROR_NOT_SUPPORTED); | ||
return FALSE; | ||
} | ||
return GetFileInformationByName(FileName, FileInformationClass, FileInfoBuffer, FileInfoBufferSize); | ||
} | ||
|
||
#endif | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 2 additions & 0 deletions
2
Misc/NEWS.d/next/Windows/2023-02-22-17-26-10.gh-issue-99726.76t957.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
Improves correctness of stat results for Windows, and uses faster API when | ||
available |
Oops, something went wrong.