summaryrefslogtreecommitdiffstats
path: root/Modules/_winapi.c
diff options
context:
space:
mode:
authorSteve Dower <steve.dower@python.org>2024-01-26 17:27:29 (GMT)
committerGitHub <noreply@github.com>2024-01-26 17:27:29 (GMT)
commit102569d150b690efe94c13921e93da66081ba1cf (patch)
treee4dc43b2b7972fe0d4776adcd334905f455f9d6b /Modules/_winapi.c
parentf9c505698a1ac27f5a380780767665ffd2fb8ebc (diff)
downloadcpython-102569d150b690efe94c13921e93da66081ba1cf.zip
cpython-102569d150b690efe94c13921e93da66081ba1cf.tar.gz
cpython-102569d150b690efe94c13921e93da66081ba1cf.tar.bz2
Use Unicode unconditionally for _winapi.CreateFile (GH-114611)
Currently it switches based on build settings, but argument clinic does not handle it correctly.
Diffstat (limited to 'Modules/_winapi.c')
-rw-r--r--Modules/_winapi.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/Modules/_winapi.c b/Modules/_winapi.c
index 26302b5..5e5eb12 100644
--- a/Modules/_winapi.c
+++ b/Modules/_winapi.c
@@ -441,7 +441,7 @@ _winapi_ConnectNamedPipe_impl(PyObject *module, HANDLE handle,
/*[clinic input]
_winapi.CreateFile -> HANDLE
- file_name: LPCTSTR
+ file_name: LPCWSTR
desired_access: DWORD
share_mode: DWORD
security_attributes: LPSECURITY_ATTRIBUTES
@@ -452,12 +452,12 @@ _winapi.CreateFile -> HANDLE
[clinic start generated code]*/
static HANDLE
-_winapi_CreateFile_impl(PyObject *module, LPCTSTR file_name,
+_winapi_CreateFile_impl(PyObject *module, LPCWSTR file_name,
DWORD desired_access, DWORD share_mode,
LPSECURITY_ATTRIBUTES security_attributes,
DWORD creation_disposition,
DWORD flags_and_attributes, HANDLE template_file)
-/*[clinic end generated code: output=417ddcebfc5a3d53 input=6423c3e40372dbd5]*/
+/*[clinic end generated code: output=818c811e5e04d550 input=1fa870ed1c2e3d69]*/
{
HANDLE handle;
@@ -468,14 +468,15 @@ _winapi_CreateFile_impl(PyObject *module, LPCTSTR file_name,
}
Py_BEGIN_ALLOW_THREADS
- handle = CreateFile(file_name, desired_access,
- share_mode, security_attributes,
- creation_disposition,
- flags_and_attributes, template_file);
+ handle = CreateFileW(file_name, desired_access,
+ share_mode, security_attributes,
+ creation_disposition,
+ flags_and_attributes, template_file);
Py_END_ALLOW_THREADS
- if (handle == INVALID_HANDLE_VALUE)
+ if (handle == INVALID_HANDLE_VALUE) {
PyErr_SetFromWindowsErr(0);
+ }
return handle;
}