blob: 5bfbaf0d56346c5022d4ffdc1613c70a9a3a2e34 [file] [log] [blame]
Zachary Waref2244ea2015-05-13 01:22:54 -05001/*[clinic input]
2preserve
3[clinic start generated code]*/
4
5PyDoc_STRVAR(_winapi_Overlapped_GetOverlappedResult__doc__,
6"GetOverlappedResult($self, wait, /)\n"
7"--\n"
8"\n");
9
10#define _WINAPI_OVERLAPPED_GETOVERLAPPEDRESULT_METHODDEF \
11 {"GetOverlappedResult", (PyCFunction)_winapi_Overlapped_GetOverlappedResult, METH_O, _winapi_Overlapped_GetOverlappedResult__doc__},
12
13static PyObject *
14_winapi_Overlapped_GetOverlappedResult_impl(OverlappedObject *self, int wait);
15
16static PyObject *
17_winapi_Overlapped_GetOverlappedResult(OverlappedObject *self, PyObject *arg)
18{
19 PyObject *return_value = NULL;
20 int wait;
21
Serhiy Storchaka5dee6552016-06-09 16:16:06 +030022 if (!PyArg_Parse(arg, "p:GetOverlappedResult", &wait)) {
Zachary Waref2244ea2015-05-13 01:22:54 -050023 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +030024 }
Zachary Waref2244ea2015-05-13 01:22:54 -050025 return_value = _winapi_Overlapped_GetOverlappedResult_impl(self, wait);
26
27exit:
28 return return_value;
29}
30
31PyDoc_STRVAR(_winapi_Overlapped_getbuffer__doc__,
32"getbuffer($self, /)\n"
33"--\n"
34"\n");
35
36#define _WINAPI_OVERLAPPED_GETBUFFER_METHODDEF \
37 {"getbuffer", (PyCFunction)_winapi_Overlapped_getbuffer, METH_NOARGS, _winapi_Overlapped_getbuffer__doc__},
38
39static PyObject *
40_winapi_Overlapped_getbuffer_impl(OverlappedObject *self);
41
42static PyObject *
43_winapi_Overlapped_getbuffer(OverlappedObject *self, PyObject *Py_UNUSED(ignored))
44{
45 return _winapi_Overlapped_getbuffer_impl(self);
46}
47
48PyDoc_STRVAR(_winapi_Overlapped_cancel__doc__,
49"cancel($self, /)\n"
50"--\n"
51"\n");
52
53#define _WINAPI_OVERLAPPED_CANCEL_METHODDEF \
54 {"cancel", (PyCFunction)_winapi_Overlapped_cancel, METH_NOARGS, _winapi_Overlapped_cancel__doc__},
55
56static PyObject *
57_winapi_Overlapped_cancel_impl(OverlappedObject *self);
58
59static PyObject *
60_winapi_Overlapped_cancel(OverlappedObject *self, PyObject *Py_UNUSED(ignored))
61{
62 return _winapi_Overlapped_cancel_impl(self);
63}
64
65PyDoc_STRVAR(_winapi_CloseHandle__doc__,
66"CloseHandle($module, handle, /)\n"
67"--\n"
68"\n"
69"Close handle.");
70
71#define _WINAPI_CLOSEHANDLE_METHODDEF \
72 {"CloseHandle", (PyCFunction)_winapi_CloseHandle, METH_O, _winapi_CloseHandle__doc__},
73
74static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +030075_winapi_CloseHandle_impl(PyObject *module, HANDLE handle);
Zachary Waref2244ea2015-05-13 01:22:54 -050076
77static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +030078_winapi_CloseHandle(PyObject *module, PyObject *arg)
Zachary Waref2244ea2015-05-13 01:22:54 -050079{
80 PyObject *return_value = NULL;
81 HANDLE handle;
82
Serhiy Storchaka5dee6552016-06-09 16:16:06 +030083 if (!PyArg_Parse(arg, "" F_HANDLE ":CloseHandle", &handle)) {
Zachary Waref2244ea2015-05-13 01:22:54 -050084 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +030085 }
Zachary Waref2244ea2015-05-13 01:22:54 -050086 return_value = _winapi_CloseHandle_impl(module, handle);
87
88exit:
89 return return_value;
90}
91
92PyDoc_STRVAR(_winapi_ConnectNamedPipe__doc__,
93"ConnectNamedPipe($module, /, handle, overlapped=False)\n"
94"--\n"
95"\n");
96
97#define _WINAPI_CONNECTNAMEDPIPE_METHODDEF \
Victor Stinner37e4ef72016-09-09 20:00:13 -070098 {"ConnectNamedPipe", (PyCFunction)_winapi_ConnectNamedPipe, METH_FASTCALL, _winapi_ConnectNamedPipe__doc__},
Zachary Waref2244ea2015-05-13 01:22:54 -050099
100static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300101_winapi_ConnectNamedPipe_impl(PyObject *module, HANDLE handle,
Zachary Ware77772c02015-05-13 10:58:35 -0500102 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500103
104static PyObject *
Victor Stinner37e4ef72016-09-09 20:00:13 -0700105_winapi_ConnectNamedPipe(PyObject *module, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
Zachary Waref2244ea2015-05-13 01:22:54 -0500106{
107 PyObject *return_value = NULL;
Serhiy Storchaka9171a8b2016-08-14 10:52:18 +0300108 static const char * const _keywords[] = {"handle", "overlapped", NULL};
109 static _PyArg_Parser _parser = {"" F_HANDLE "|i:ConnectNamedPipe", _keywords, 0};
Zachary Waref2244ea2015-05-13 01:22:54 -0500110 HANDLE handle;
111 int use_overlapped = 0;
112
Victor Stinner37e4ef72016-09-09 20:00:13 -0700113 if (!_PyArg_ParseStack(args, nargs, kwnames, &_parser,
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300114 &handle, &use_overlapped)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500115 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300116 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500117 return_value = _winapi_ConnectNamedPipe_impl(module, handle, use_overlapped);
118
119exit:
120 return return_value;
121}
122
123PyDoc_STRVAR(_winapi_CreateFile__doc__,
124"CreateFile($module, file_name, desired_access, share_mode,\n"
125" security_attributes, creation_disposition,\n"
126" flags_and_attributes, template_file, /)\n"
127"--\n"
128"\n");
129
130#define _WINAPI_CREATEFILE_METHODDEF \
131 {"CreateFile", (PyCFunction)_winapi_CreateFile, METH_VARARGS, _winapi_CreateFile__doc__},
132
133static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300134_winapi_CreateFile_impl(PyObject *module, LPCTSTR file_name,
Zachary Ware77772c02015-05-13 10:58:35 -0500135 DWORD desired_access, DWORD share_mode,
136 LPSECURITY_ATTRIBUTES security_attributes,
137 DWORD creation_disposition,
138 DWORD flags_and_attributes, HANDLE template_file);
Zachary Waref2244ea2015-05-13 01:22:54 -0500139
140static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300141_winapi_CreateFile(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500142{
143 PyObject *return_value = NULL;
144 LPCTSTR file_name;
145 DWORD desired_access;
146 DWORD share_mode;
147 LPSECURITY_ATTRIBUTES security_attributes;
148 DWORD creation_disposition;
149 DWORD flags_and_attributes;
150 HANDLE template_file;
151 HANDLE _return_value;
152
Zachary Ware77772c02015-05-13 10:58:35 -0500153 if (!PyArg_ParseTuple(args, "skk" F_POINTER "kk" F_HANDLE ":CreateFile",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300154 &file_name, &desired_access, &share_mode, &security_attributes, &creation_disposition, &flags_and_attributes, &template_file)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500155 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300156 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500157 _return_value = _winapi_CreateFile_impl(module, file_name, desired_access, share_mode, security_attributes, creation_disposition, flags_and_attributes, template_file);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300158 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500159 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300160 }
161 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500162 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300163 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500164 return_value = HANDLE_TO_PYNUM(_return_value);
165
166exit:
167 return return_value;
168}
169
170PyDoc_STRVAR(_winapi_CreateJunction__doc__,
171"CreateJunction($module, src_path, dst_path, /)\n"
172"--\n"
173"\n");
174
175#define _WINAPI_CREATEJUNCTION_METHODDEF \
176 {"CreateJunction", (PyCFunction)_winapi_CreateJunction, METH_VARARGS, _winapi_CreateJunction__doc__},
177
178static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300179_winapi_CreateJunction_impl(PyObject *module, LPWSTR src_path,
Zachary Ware77772c02015-05-13 10:58:35 -0500180 LPWSTR dst_path);
Zachary Waref2244ea2015-05-13 01:22:54 -0500181
182static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300183_winapi_CreateJunction(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500184{
185 PyObject *return_value = NULL;
186 LPWSTR src_path;
187 LPWSTR dst_path;
188
Zachary Ware77772c02015-05-13 10:58:35 -0500189 if (!PyArg_ParseTuple(args, "uu:CreateJunction",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300190 &src_path, &dst_path)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500191 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300192 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500193 return_value = _winapi_CreateJunction_impl(module, src_path, dst_path);
194
195exit:
196 return return_value;
197}
198
199PyDoc_STRVAR(_winapi_CreateNamedPipe__doc__,
200"CreateNamedPipe($module, name, open_mode, pipe_mode, max_instances,\n"
201" out_buffer_size, in_buffer_size, default_timeout,\n"
202" security_attributes, /)\n"
203"--\n"
204"\n");
205
206#define _WINAPI_CREATENAMEDPIPE_METHODDEF \
207 {"CreateNamedPipe", (PyCFunction)_winapi_CreateNamedPipe, METH_VARARGS, _winapi_CreateNamedPipe__doc__},
208
209static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300210_winapi_CreateNamedPipe_impl(PyObject *module, LPCTSTR name, DWORD open_mode,
211 DWORD pipe_mode, DWORD max_instances,
212 DWORD out_buffer_size, DWORD in_buffer_size,
213 DWORD default_timeout,
Zachary Ware77772c02015-05-13 10:58:35 -0500214 LPSECURITY_ATTRIBUTES security_attributes);
Zachary Waref2244ea2015-05-13 01:22:54 -0500215
216static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300217_winapi_CreateNamedPipe(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500218{
219 PyObject *return_value = NULL;
220 LPCTSTR name;
221 DWORD open_mode;
222 DWORD pipe_mode;
223 DWORD max_instances;
224 DWORD out_buffer_size;
225 DWORD in_buffer_size;
226 DWORD default_timeout;
227 LPSECURITY_ATTRIBUTES security_attributes;
228 HANDLE _return_value;
229
Zachary Ware77772c02015-05-13 10:58:35 -0500230 if (!PyArg_ParseTuple(args, "skkkkkk" F_POINTER ":CreateNamedPipe",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300231 &name, &open_mode, &pipe_mode, &max_instances, &out_buffer_size, &in_buffer_size, &default_timeout, &security_attributes)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500232 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300233 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500234 _return_value = _winapi_CreateNamedPipe_impl(module, name, open_mode, pipe_mode, max_instances, out_buffer_size, in_buffer_size, default_timeout, security_attributes);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300235 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500236 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300237 }
238 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500239 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300240 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500241 return_value = HANDLE_TO_PYNUM(_return_value);
242
243exit:
244 return return_value;
245}
246
247PyDoc_STRVAR(_winapi_CreatePipe__doc__,
248"CreatePipe($module, pipe_attrs, size, /)\n"
249"--\n"
250"\n"
251"Create an anonymous pipe.\n"
252"\n"
253" pipe_attrs\n"
254" Ignored internally, can be None.\n"
255"\n"
256"Returns a 2-tuple of handles, to the read and write ends of the pipe.");
257
258#define _WINAPI_CREATEPIPE_METHODDEF \
259 {"CreatePipe", (PyCFunction)_winapi_CreatePipe, METH_VARARGS, _winapi_CreatePipe__doc__},
260
261static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300262_winapi_CreatePipe_impl(PyObject *module, PyObject *pipe_attrs, DWORD size);
Zachary Waref2244ea2015-05-13 01:22:54 -0500263
264static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300265_winapi_CreatePipe(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500266{
267 PyObject *return_value = NULL;
268 PyObject *pipe_attrs;
269 DWORD size;
270
Zachary Ware77772c02015-05-13 10:58:35 -0500271 if (!PyArg_ParseTuple(args, "Ok:CreatePipe",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300272 &pipe_attrs, &size)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500273 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300274 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500275 return_value = _winapi_CreatePipe_impl(module, pipe_attrs, size);
276
277exit:
278 return return_value;
279}
280
281PyDoc_STRVAR(_winapi_CreateProcess__doc__,
282"CreateProcess($module, application_name, command_line, proc_attrs,\n"
283" thread_attrs, inherit_handles, creation_flags,\n"
284" env_mapping, current_directory, startup_info, /)\n"
285"--\n"
286"\n"
287"Create a new process and its primary thread.\n"
288"\n"
289" proc_attrs\n"
290" Ignored internally, can be None.\n"
291" thread_attrs\n"
292" Ignored internally, can be None.\n"
293"\n"
294"The return value is a tuple of the process handle, thread handle,\n"
295"process ID, and thread ID.");
296
297#define _WINAPI_CREATEPROCESS_METHODDEF \
298 {"CreateProcess", (PyCFunction)_winapi_CreateProcess, METH_VARARGS, _winapi_CreateProcess__doc__},
299
300static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300301_winapi_CreateProcess_impl(PyObject *module, Py_UNICODE *application_name,
Zachary Ware77772c02015-05-13 10:58:35 -0500302 Py_UNICODE *command_line, PyObject *proc_attrs,
303 PyObject *thread_attrs, BOOL inherit_handles,
304 DWORD creation_flags, PyObject *env_mapping,
305 Py_UNICODE *current_directory,
306 PyObject *startup_info);
Zachary Waref2244ea2015-05-13 01:22:54 -0500307
308static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300309_winapi_CreateProcess(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500310{
311 PyObject *return_value = NULL;
312 Py_UNICODE *application_name;
313 Py_UNICODE *command_line;
314 PyObject *proc_attrs;
315 PyObject *thread_attrs;
316 BOOL inherit_handles;
317 DWORD creation_flags;
318 PyObject *env_mapping;
319 Py_UNICODE *current_directory;
320 PyObject *startup_info;
321
Zachary Ware77772c02015-05-13 10:58:35 -0500322 if (!PyArg_ParseTuple(args, "ZZOOikOZO:CreateProcess",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300323 &application_name, &command_line, &proc_attrs, &thread_attrs, &inherit_handles, &creation_flags, &env_mapping, &current_directory, &startup_info)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500324 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300325 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500326 return_value = _winapi_CreateProcess_impl(module, application_name, command_line, proc_attrs, thread_attrs, inherit_handles, creation_flags, env_mapping, current_directory, startup_info);
327
328exit:
329 return return_value;
330}
331
332PyDoc_STRVAR(_winapi_DuplicateHandle__doc__,
333"DuplicateHandle($module, source_process_handle, source_handle,\n"
334" target_process_handle, desired_access, inherit_handle,\n"
335" options=0, /)\n"
336"--\n"
337"\n"
338"Return a duplicate handle object.\n"
339"\n"
340"The duplicate handle refers to the same object as the original\n"
341"handle. Therefore, any changes to the object are reflected\n"
342"through both handles.");
343
344#define _WINAPI_DUPLICATEHANDLE_METHODDEF \
345 {"DuplicateHandle", (PyCFunction)_winapi_DuplicateHandle, METH_VARARGS, _winapi_DuplicateHandle__doc__},
346
347static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300348_winapi_DuplicateHandle_impl(PyObject *module, HANDLE source_process_handle,
Zachary Ware77772c02015-05-13 10:58:35 -0500349 HANDLE source_handle,
350 HANDLE target_process_handle,
351 DWORD desired_access, BOOL inherit_handle,
352 DWORD options);
Zachary Waref2244ea2015-05-13 01:22:54 -0500353
354static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300355_winapi_DuplicateHandle(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500356{
357 PyObject *return_value = NULL;
358 HANDLE source_process_handle;
359 HANDLE source_handle;
360 HANDLE target_process_handle;
361 DWORD desired_access;
362 BOOL inherit_handle;
363 DWORD options = 0;
364 HANDLE _return_value;
365
Zachary Ware77772c02015-05-13 10:58:35 -0500366 if (!PyArg_ParseTuple(args, "" F_HANDLE "" F_HANDLE "" F_HANDLE "ki|k:DuplicateHandle",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300367 &source_process_handle, &source_handle, &target_process_handle, &desired_access, &inherit_handle, &options)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500368 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300369 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500370 _return_value = _winapi_DuplicateHandle_impl(module, source_process_handle, source_handle, target_process_handle, desired_access, inherit_handle, options);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300371 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500372 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300373 }
374 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500375 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300376 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500377 return_value = HANDLE_TO_PYNUM(_return_value);
378
379exit:
380 return return_value;
381}
382
383PyDoc_STRVAR(_winapi_ExitProcess__doc__,
384"ExitProcess($module, ExitCode, /)\n"
385"--\n"
386"\n");
387
388#define _WINAPI_EXITPROCESS_METHODDEF \
389 {"ExitProcess", (PyCFunction)_winapi_ExitProcess, METH_O, _winapi_ExitProcess__doc__},
390
391static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300392_winapi_ExitProcess_impl(PyObject *module, UINT ExitCode);
Zachary Waref2244ea2015-05-13 01:22:54 -0500393
394static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300395_winapi_ExitProcess(PyObject *module, PyObject *arg)
Zachary Waref2244ea2015-05-13 01:22:54 -0500396{
397 PyObject *return_value = NULL;
398 UINT ExitCode;
399
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300400 if (!PyArg_Parse(arg, "I:ExitProcess", &ExitCode)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500401 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300402 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500403 return_value = _winapi_ExitProcess_impl(module, ExitCode);
404
405exit:
406 return return_value;
407}
408
409PyDoc_STRVAR(_winapi_GetCurrentProcess__doc__,
410"GetCurrentProcess($module, /)\n"
411"--\n"
412"\n"
413"Return a handle object for the current process.");
414
415#define _WINAPI_GETCURRENTPROCESS_METHODDEF \
416 {"GetCurrentProcess", (PyCFunction)_winapi_GetCurrentProcess, METH_NOARGS, _winapi_GetCurrentProcess__doc__},
417
418static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300419_winapi_GetCurrentProcess_impl(PyObject *module);
Zachary Waref2244ea2015-05-13 01:22:54 -0500420
421static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300422_winapi_GetCurrentProcess(PyObject *module, PyObject *Py_UNUSED(ignored))
Zachary Waref2244ea2015-05-13 01:22:54 -0500423{
424 PyObject *return_value = NULL;
425 HANDLE _return_value;
426
427 _return_value = _winapi_GetCurrentProcess_impl(module);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300428 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500429 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300430 }
431 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500432 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300433 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500434 return_value = HANDLE_TO_PYNUM(_return_value);
435
436exit:
437 return return_value;
438}
439
440PyDoc_STRVAR(_winapi_GetExitCodeProcess__doc__,
441"GetExitCodeProcess($module, process, /)\n"
442"--\n"
443"\n"
444"Return the termination status of the specified process.");
445
446#define _WINAPI_GETEXITCODEPROCESS_METHODDEF \
447 {"GetExitCodeProcess", (PyCFunction)_winapi_GetExitCodeProcess, METH_O, _winapi_GetExitCodeProcess__doc__},
448
449static DWORD
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300450_winapi_GetExitCodeProcess_impl(PyObject *module, HANDLE process);
Zachary Waref2244ea2015-05-13 01:22:54 -0500451
452static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300453_winapi_GetExitCodeProcess(PyObject *module, PyObject *arg)
Zachary Waref2244ea2015-05-13 01:22:54 -0500454{
455 PyObject *return_value = NULL;
456 HANDLE process;
457 DWORD _return_value;
458
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300459 if (!PyArg_Parse(arg, "" F_HANDLE ":GetExitCodeProcess", &process)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500460 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300461 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500462 _return_value = _winapi_GetExitCodeProcess_impl(module, process);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300463 if ((_return_value == DWORD_MAX) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500464 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300465 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500466 return_value = Py_BuildValue("k", _return_value);
467
468exit:
469 return return_value;
470}
471
472PyDoc_STRVAR(_winapi_GetLastError__doc__,
473"GetLastError($module, /)\n"
474"--\n"
475"\n");
476
477#define _WINAPI_GETLASTERROR_METHODDEF \
478 {"GetLastError", (PyCFunction)_winapi_GetLastError, METH_NOARGS, _winapi_GetLastError__doc__},
479
480static DWORD
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300481_winapi_GetLastError_impl(PyObject *module);
Zachary Waref2244ea2015-05-13 01:22:54 -0500482
483static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300484_winapi_GetLastError(PyObject *module, PyObject *Py_UNUSED(ignored))
Zachary Waref2244ea2015-05-13 01:22:54 -0500485{
486 PyObject *return_value = NULL;
487 DWORD _return_value;
488
489 _return_value = _winapi_GetLastError_impl(module);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300490 if ((_return_value == DWORD_MAX) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500491 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300492 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500493 return_value = Py_BuildValue("k", _return_value);
494
495exit:
496 return return_value;
497}
498
499PyDoc_STRVAR(_winapi_GetModuleFileName__doc__,
500"GetModuleFileName($module, module_handle, /)\n"
501"--\n"
502"\n"
503"Return the fully-qualified path for the file that contains module.\n"
504"\n"
505"The module must have been loaded by the current process.\n"
506"\n"
507"The module parameter should be a handle to the loaded module\n"
508"whose path is being requested. If this parameter is 0,\n"
509"GetModuleFileName retrieves the path of the executable file\n"
510"of the current process.");
511
512#define _WINAPI_GETMODULEFILENAME_METHODDEF \
513 {"GetModuleFileName", (PyCFunction)_winapi_GetModuleFileName, METH_O, _winapi_GetModuleFileName__doc__},
514
515static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300516_winapi_GetModuleFileName_impl(PyObject *module, HMODULE module_handle);
Zachary Waref2244ea2015-05-13 01:22:54 -0500517
518static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300519_winapi_GetModuleFileName(PyObject *module, PyObject *arg)
Zachary Waref2244ea2015-05-13 01:22:54 -0500520{
521 PyObject *return_value = NULL;
522 HMODULE module_handle;
523
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300524 if (!PyArg_Parse(arg, "" F_HANDLE ":GetModuleFileName", &module_handle)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500525 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300526 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500527 return_value = _winapi_GetModuleFileName_impl(module, module_handle);
528
529exit:
530 return return_value;
531}
532
533PyDoc_STRVAR(_winapi_GetStdHandle__doc__,
534"GetStdHandle($module, std_handle, /)\n"
535"--\n"
536"\n"
537"Return a handle to the specified standard device.\n"
538"\n"
539" std_handle\n"
540" One of STD_INPUT_HANDLE, STD_OUTPUT_HANDLE, or STD_ERROR_HANDLE.\n"
541"\n"
542"The integer associated with the handle object is returned.");
543
544#define _WINAPI_GETSTDHANDLE_METHODDEF \
545 {"GetStdHandle", (PyCFunction)_winapi_GetStdHandle, METH_O, _winapi_GetStdHandle__doc__},
546
547static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300548_winapi_GetStdHandle_impl(PyObject *module, DWORD std_handle);
Zachary Waref2244ea2015-05-13 01:22:54 -0500549
550static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300551_winapi_GetStdHandle(PyObject *module, PyObject *arg)
Zachary Waref2244ea2015-05-13 01:22:54 -0500552{
553 PyObject *return_value = NULL;
554 DWORD std_handle;
555 HANDLE _return_value;
556
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300557 if (!PyArg_Parse(arg, "k:GetStdHandle", &std_handle)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500558 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300559 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500560 _return_value = _winapi_GetStdHandle_impl(module, std_handle);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300561 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500562 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300563 }
564 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500565 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300566 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500567 return_value = HANDLE_TO_PYNUM(_return_value);
568
569exit:
570 return return_value;
571}
572
573PyDoc_STRVAR(_winapi_GetVersion__doc__,
574"GetVersion($module, /)\n"
575"--\n"
576"\n"
577"Return the version number of the current operating system.");
578
579#define _WINAPI_GETVERSION_METHODDEF \
580 {"GetVersion", (PyCFunction)_winapi_GetVersion, METH_NOARGS, _winapi_GetVersion__doc__},
581
582static long
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300583_winapi_GetVersion_impl(PyObject *module);
Zachary Waref2244ea2015-05-13 01:22:54 -0500584
585static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300586_winapi_GetVersion(PyObject *module, PyObject *Py_UNUSED(ignored))
Zachary Waref2244ea2015-05-13 01:22:54 -0500587{
588 PyObject *return_value = NULL;
589 long _return_value;
590
591 _return_value = _winapi_GetVersion_impl(module);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300592 if ((_return_value == -1) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500593 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300594 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500595 return_value = PyLong_FromLong(_return_value);
596
597exit:
598 return return_value;
599}
600
601PyDoc_STRVAR(_winapi_OpenProcess__doc__,
602"OpenProcess($module, desired_access, inherit_handle, process_id, /)\n"
603"--\n"
604"\n");
605
606#define _WINAPI_OPENPROCESS_METHODDEF \
607 {"OpenProcess", (PyCFunction)_winapi_OpenProcess, METH_VARARGS, _winapi_OpenProcess__doc__},
608
609static HANDLE
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300610_winapi_OpenProcess_impl(PyObject *module, DWORD desired_access,
Zachary Ware77772c02015-05-13 10:58:35 -0500611 BOOL inherit_handle, DWORD process_id);
Zachary Waref2244ea2015-05-13 01:22:54 -0500612
613static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300614_winapi_OpenProcess(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500615{
616 PyObject *return_value = NULL;
617 DWORD desired_access;
618 BOOL inherit_handle;
619 DWORD process_id;
620 HANDLE _return_value;
621
Zachary Ware77772c02015-05-13 10:58:35 -0500622 if (!PyArg_ParseTuple(args, "kik:OpenProcess",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300623 &desired_access, &inherit_handle, &process_id)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500624 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300625 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500626 _return_value = _winapi_OpenProcess_impl(module, desired_access, inherit_handle, process_id);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300627 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500628 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300629 }
630 if (_return_value == NULL) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500631 Py_RETURN_NONE;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300632 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500633 return_value = HANDLE_TO_PYNUM(_return_value);
634
635exit:
636 return return_value;
637}
638
639PyDoc_STRVAR(_winapi_PeekNamedPipe__doc__,
640"PeekNamedPipe($module, handle, size=0, /)\n"
641"--\n"
642"\n");
643
644#define _WINAPI_PEEKNAMEDPIPE_METHODDEF \
645 {"PeekNamedPipe", (PyCFunction)_winapi_PeekNamedPipe, METH_VARARGS, _winapi_PeekNamedPipe__doc__},
646
647static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300648_winapi_PeekNamedPipe_impl(PyObject *module, HANDLE handle, int size);
Zachary Waref2244ea2015-05-13 01:22:54 -0500649
650static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300651_winapi_PeekNamedPipe(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500652{
653 PyObject *return_value = NULL;
654 HANDLE handle;
655 int size = 0;
656
Zachary Ware77772c02015-05-13 10:58:35 -0500657 if (!PyArg_ParseTuple(args, "" F_HANDLE "|i:PeekNamedPipe",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300658 &handle, &size)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500659 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300660 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500661 return_value = _winapi_PeekNamedPipe_impl(module, handle, size);
662
663exit:
664 return return_value;
665}
666
667PyDoc_STRVAR(_winapi_ReadFile__doc__,
668"ReadFile($module, /, handle, size, overlapped=False)\n"
669"--\n"
670"\n");
671
672#define _WINAPI_READFILE_METHODDEF \
Victor Stinner37e4ef72016-09-09 20:00:13 -0700673 {"ReadFile", (PyCFunction)_winapi_ReadFile, METH_FASTCALL, _winapi_ReadFile__doc__},
Zachary Waref2244ea2015-05-13 01:22:54 -0500674
675static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300676_winapi_ReadFile_impl(PyObject *module, HANDLE handle, int size,
Zachary Ware77772c02015-05-13 10:58:35 -0500677 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500678
679static PyObject *
Victor Stinner37e4ef72016-09-09 20:00:13 -0700680_winapi_ReadFile(PyObject *module, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
Zachary Waref2244ea2015-05-13 01:22:54 -0500681{
682 PyObject *return_value = NULL;
Serhiy Storchaka9171a8b2016-08-14 10:52:18 +0300683 static const char * const _keywords[] = {"handle", "size", "overlapped", NULL};
684 static _PyArg_Parser _parser = {"" F_HANDLE "i|i:ReadFile", _keywords, 0};
Zachary Waref2244ea2015-05-13 01:22:54 -0500685 HANDLE handle;
686 int size;
687 int use_overlapped = 0;
688
Victor Stinner37e4ef72016-09-09 20:00:13 -0700689 if (!_PyArg_ParseStack(args, nargs, kwnames, &_parser,
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300690 &handle, &size, &use_overlapped)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500691 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300692 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500693 return_value = _winapi_ReadFile_impl(module, handle, size, use_overlapped);
694
695exit:
696 return return_value;
697}
698
699PyDoc_STRVAR(_winapi_SetNamedPipeHandleState__doc__,
700"SetNamedPipeHandleState($module, named_pipe, mode,\n"
701" max_collection_count, collect_data_timeout, /)\n"
702"--\n"
703"\n");
704
705#define _WINAPI_SETNAMEDPIPEHANDLESTATE_METHODDEF \
706 {"SetNamedPipeHandleState", (PyCFunction)_winapi_SetNamedPipeHandleState, METH_VARARGS, _winapi_SetNamedPipeHandleState__doc__},
707
708static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300709_winapi_SetNamedPipeHandleState_impl(PyObject *module, HANDLE named_pipe,
Zachary Ware77772c02015-05-13 10:58:35 -0500710 PyObject *mode,
711 PyObject *max_collection_count,
712 PyObject *collect_data_timeout);
Zachary Waref2244ea2015-05-13 01:22:54 -0500713
714static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300715_winapi_SetNamedPipeHandleState(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500716{
717 PyObject *return_value = NULL;
718 HANDLE named_pipe;
719 PyObject *mode;
720 PyObject *max_collection_count;
721 PyObject *collect_data_timeout;
722
Zachary Ware77772c02015-05-13 10:58:35 -0500723 if (!PyArg_ParseTuple(args, "" F_HANDLE "OOO:SetNamedPipeHandleState",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300724 &named_pipe, &mode, &max_collection_count, &collect_data_timeout)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500725 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300726 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500727 return_value = _winapi_SetNamedPipeHandleState_impl(module, named_pipe, mode, max_collection_count, collect_data_timeout);
728
729exit:
730 return return_value;
731}
732
733PyDoc_STRVAR(_winapi_TerminateProcess__doc__,
734"TerminateProcess($module, handle, exit_code, /)\n"
735"--\n"
736"\n"
737"Terminate the specified process and all of its threads.");
738
739#define _WINAPI_TERMINATEPROCESS_METHODDEF \
740 {"TerminateProcess", (PyCFunction)_winapi_TerminateProcess, METH_VARARGS, _winapi_TerminateProcess__doc__},
741
742static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300743_winapi_TerminateProcess_impl(PyObject *module, HANDLE handle,
Zachary Ware77772c02015-05-13 10:58:35 -0500744 UINT exit_code);
Zachary Waref2244ea2015-05-13 01:22:54 -0500745
746static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300747_winapi_TerminateProcess(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500748{
749 PyObject *return_value = NULL;
750 HANDLE handle;
751 UINT exit_code;
752
Zachary Ware77772c02015-05-13 10:58:35 -0500753 if (!PyArg_ParseTuple(args, "" F_HANDLE "I:TerminateProcess",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300754 &handle, &exit_code)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500755 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300756 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500757 return_value = _winapi_TerminateProcess_impl(module, handle, exit_code);
758
759exit:
760 return return_value;
761}
762
763PyDoc_STRVAR(_winapi_WaitNamedPipe__doc__,
764"WaitNamedPipe($module, name, timeout, /)\n"
765"--\n"
766"\n");
767
768#define _WINAPI_WAITNAMEDPIPE_METHODDEF \
769 {"WaitNamedPipe", (PyCFunction)_winapi_WaitNamedPipe, METH_VARARGS, _winapi_WaitNamedPipe__doc__},
770
771static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300772_winapi_WaitNamedPipe_impl(PyObject *module, LPCTSTR name, DWORD timeout);
Zachary Waref2244ea2015-05-13 01:22:54 -0500773
774static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300775_winapi_WaitNamedPipe(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500776{
777 PyObject *return_value = NULL;
778 LPCTSTR name;
779 DWORD timeout;
780
Zachary Ware77772c02015-05-13 10:58:35 -0500781 if (!PyArg_ParseTuple(args, "sk:WaitNamedPipe",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300782 &name, &timeout)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500783 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300784 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500785 return_value = _winapi_WaitNamedPipe_impl(module, name, timeout);
786
787exit:
788 return return_value;
789}
790
791PyDoc_STRVAR(_winapi_WaitForMultipleObjects__doc__,
792"WaitForMultipleObjects($module, handle_seq, wait_flag,\n"
793" milliseconds=_winapi.INFINITE, /)\n"
794"--\n"
795"\n");
796
797#define _WINAPI_WAITFORMULTIPLEOBJECTS_METHODDEF \
798 {"WaitForMultipleObjects", (PyCFunction)_winapi_WaitForMultipleObjects, METH_VARARGS, _winapi_WaitForMultipleObjects__doc__},
799
800static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300801_winapi_WaitForMultipleObjects_impl(PyObject *module, PyObject *handle_seq,
802 BOOL wait_flag, DWORD milliseconds);
Zachary Waref2244ea2015-05-13 01:22:54 -0500803
804static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300805_winapi_WaitForMultipleObjects(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500806{
807 PyObject *return_value = NULL;
808 PyObject *handle_seq;
809 BOOL wait_flag;
810 DWORD milliseconds = INFINITE;
811
Zachary Ware77772c02015-05-13 10:58:35 -0500812 if (!PyArg_ParseTuple(args, "Oi|k:WaitForMultipleObjects",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300813 &handle_seq, &wait_flag, &milliseconds)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500814 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300815 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500816 return_value = _winapi_WaitForMultipleObjects_impl(module, handle_seq, wait_flag, milliseconds);
817
818exit:
819 return return_value;
820}
821
822PyDoc_STRVAR(_winapi_WaitForSingleObject__doc__,
823"WaitForSingleObject($module, handle, milliseconds, /)\n"
824"--\n"
825"\n"
826"Wait for a single object.\n"
827"\n"
828"Wait until the specified object is in the signaled state or\n"
829"the time-out interval elapses. The timeout value is specified\n"
830"in milliseconds.");
831
832#define _WINAPI_WAITFORSINGLEOBJECT_METHODDEF \
833 {"WaitForSingleObject", (PyCFunction)_winapi_WaitForSingleObject, METH_VARARGS, _winapi_WaitForSingleObject__doc__},
834
835static long
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300836_winapi_WaitForSingleObject_impl(PyObject *module, HANDLE handle,
Zachary Ware77772c02015-05-13 10:58:35 -0500837 DWORD milliseconds);
Zachary Waref2244ea2015-05-13 01:22:54 -0500838
839static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300840_winapi_WaitForSingleObject(PyObject *module, PyObject *args)
Zachary Waref2244ea2015-05-13 01:22:54 -0500841{
842 PyObject *return_value = NULL;
843 HANDLE handle;
844 DWORD milliseconds;
845 long _return_value;
846
Zachary Ware77772c02015-05-13 10:58:35 -0500847 if (!PyArg_ParseTuple(args, "" F_HANDLE "k:WaitForSingleObject",
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300848 &handle, &milliseconds)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500849 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300850 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500851 _return_value = _winapi_WaitForSingleObject_impl(module, handle, milliseconds);
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300852 if ((_return_value == -1) && PyErr_Occurred()) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500853 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300854 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500855 return_value = PyLong_FromLong(_return_value);
856
857exit:
858 return return_value;
859}
860
861PyDoc_STRVAR(_winapi_WriteFile__doc__,
862"WriteFile($module, /, handle, buffer, overlapped=False)\n"
863"--\n"
864"\n");
865
866#define _WINAPI_WRITEFILE_METHODDEF \
Victor Stinner37e4ef72016-09-09 20:00:13 -0700867 {"WriteFile", (PyCFunction)_winapi_WriteFile, METH_FASTCALL, _winapi_WriteFile__doc__},
Zachary Waref2244ea2015-05-13 01:22:54 -0500868
869static PyObject *
Serhiy Storchaka1a2b24f2016-07-07 17:35:15 +0300870_winapi_WriteFile_impl(PyObject *module, HANDLE handle, PyObject *buffer,
Zachary Ware77772c02015-05-13 10:58:35 -0500871 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500872
873static PyObject *
Victor Stinner37e4ef72016-09-09 20:00:13 -0700874_winapi_WriteFile(PyObject *module, PyObject **args, Py_ssize_t nargs, PyObject *kwnames)
Zachary Waref2244ea2015-05-13 01:22:54 -0500875{
876 PyObject *return_value = NULL;
Serhiy Storchaka9171a8b2016-08-14 10:52:18 +0300877 static const char * const _keywords[] = {"handle", "buffer", "overlapped", NULL};
878 static _PyArg_Parser _parser = {"" F_HANDLE "O|i:WriteFile", _keywords, 0};
Zachary Waref2244ea2015-05-13 01:22:54 -0500879 HANDLE handle;
880 PyObject *buffer;
881 int use_overlapped = 0;
882
Victor Stinner37e4ef72016-09-09 20:00:13 -0700883 if (!_PyArg_ParseStack(args, nargs, kwnames, &_parser,
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300884 &handle, &buffer, &use_overlapped)) {
Zachary Waref2244ea2015-05-13 01:22:54 -0500885 goto exit;
Serhiy Storchaka5dee6552016-06-09 16:16:06 +0300886 }
Zachary Waref2244ea2015-05-13 01:22:54 -0500887 return_value = _winapi_WriteFile_impl(module, handle, buffer, use_overlapped);
888
889exit:
890 return return_value;
891}
Victor Stinner37e4ef72016-09-09 20:00:13 -0700892/*[clinic end generated code: output=46d6382a6662c4a9 input=a9049054013a1b77]*/