blob: 34518e836bcd6f4c5be171d68a9ccef77b5bd9e7 [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
Zachary Ware77772c02015-05-13 10:58:35 -050022 if (!PyArg_Parse(arg, "p:GetOverlappedResult", &wait))
Zachary Waref2244ea2015-05-13 01:22:54 -050023 goto exit;
24 return_value = _winapi_Overlapped_GetOverlappedResult_impl(self, wait);
25
26exit:
27 return return_value;
28}
29
30PyDoc_STRVAR(_winapi_Overlapped_getbuffer__doc__,
31"getbuffer($self, /)\n"
32"--\n"
33"\n");
34
35#define _WINAPI_OVERLAPPED_GETBUFFER_METHODDEF \
36 {"getbuffer", (PyCFunction)_winapi_Overlapped_getbuffer, METH_NOARGS, _winapi_Overlapped_getbuffer__doc__},
37
38static PyObject *
39_winapi_Overlapped_getbuffer_impl(OverlappedObject *self);
40
41static PyObject *
42_winapi_Overlapped_getbuffer(OverlappedObject *self, PyObject *Py_UNUSED(ignored))
43{
44 return _winapi_Overlapped_getbuffer_impl(self);
45}
46
47PyDoc_STRVAR(_winapi_Overlapped_cancel__doc__,
48"cancel($self, /)\n"
49"--\n"
50"\n");
51
52#define _WINAPI_OVERLAPPED_CANCEL_METHODDEF \
53 {"cancel", (PyCFunction)_winapi_Overlapped_cancel, METH_NOARGS, _winapi_Overlapped_cancel__doc__},
54
55static PyObject *
56_winapi_Overlapped_cancel_impl(OverlappedObject *self);
57
58static PyObject *
59_winapi_Overlapped_cancel(OverlappedObject *self, PyObject *Py_UNUSED(ignored))
60{
61 return _winapi_Overlapped_cancel_impl(self);
62}
63
64PyDoc_STRVAR(_winapi_CloseHandle__doc__,
65"CloseHandle($module, handle, /)\n"
66"--\n"
67"\n"
68"Close handle.");
69
70#define _WINAPI_CLOSEHANDLE_METHODDEF \
71 {"CloseHandle", (PyCFunction)_winapi_CloseHandle, METH_O, _winapi_CloseHandle__doc__},
72
73static PyObject *
74_winapi_CloseHandle_impl(PyModuleDef *module, HANDLE handle);
75
76static PyObject *
77_winapi_CloseHandle(PyModuleDef *module, PyObject *arg)
78{
79 PyObject *return_value = NULL;
80 HANDLE handle;
81
Zachary Ware77772c02015-05-13 10:58:35 -050082 if (!PyArg_Parse(arg, "" F_HANDLE ":CloseHandle", &handle))
Zachary Waref2244ea2015-05-13 01:22:54 -050083 goto exit;
84 return_value = _winapi_CloseHandle_impl(module, handle);
85
86exit:
87 return return_value;
88}
89
90PyDoc_STRVAR(_winapi_ConnectNamedPipe__doc__,
91"ConnectNamedPipe($module, /, handle, overlapped=False)\n"
92"--\n"
93"\n");
94
95#define _WINAPI_CONNECTNAMEDPIPE_METHODDEF \
96 {"ConnectNamedPipe", (PyCFunction)_winapi_ConnectNamedPipe, METH_VARARGS|METH_KEYWORDS, _winapi_ConnectNamedPipe__doc__},
97
98static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -050099_winapi_ConnectNamedPipe_impl(PyModuleDef *module, HANDLE handle,
100 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500101
102static PyObject *
103_winapi_ConnectNamedPipe(PyModuleDef *module, PyObject *args, PyObject *kwargs)
104{
105 PyObject *return_value = NULL;
106 static char *_keywords[] = {"handle", "overlapped", NULL};
107 HANDLE handle;
108 int use_overlapped = 0;
109
Zachary Ware77772c02015-05-13 10:58:35 -0500110 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "" F_HANDLE "|i:ConnectNamedPipe", _keywords,
Zachary Waref2244ea2015-05-13 01:22:54 -0500111 &handle, &use_overlapped))
112 goto exit;
113 return_value = _winapi_ConnectNamedPipe_impl(module, handle, use_overlapped);
114
115exit:
116 return return_value;
117}
118
119PyDoc_STRVAR(_winapi_CreateFile__doc__,
120"CreateFile($module, file_name, desired_access, share_mode,\n"
121" security_attributes, creation_disposition,\n"
122" flags_and_attributes, template_file, /)\n"
123"--\n"
124"\n");
125
126#define _WINAPI_CREATEFILE_METHODDEF \
127 {"CreateFile", (PyCFunction)_winapi_CreateFile, METH_VARARGS, _winapi_CreateFile__doc__},
128
129static HANDLE
Zachary Ware77772c02015-05-13 10:58:35 -0500130_winapi_CreateFile_impl(PyModuleDef *module, LPCTSTR file_name,
131 DWORD desired_access, DWORD share_mode,
132 LPSECURITY_ATTRIBUTES security_attributes,
133 DWORD creation_disposition,
134 DWORD flags_and_attributes, HANDLE template_file);
Zachary Waref2244ea2015-05-13 01:22:54 -0500135
136static PyObject *
137_winapi_CreateFile(PyModuleDef *module, PyObject *args)
138{
139 PyObject *return_value = NULL;
140 LPCTSTR file_name;
141 DWORD desired_access;
142 DWORD share_mode;
143 LPSECURITY_ATTRIBUTES security_attributes;
144 DWORD creation_disposition;
145 DWORD flags_and_attributes;
146 HANDLE template_file;
147 HANDLE _return_value;
148
Zachary Ware77772c02015-05-13 10:58:35 -0500149 if (!PyArg_ParseTuple(args, "skk" F_POINTER "kk" F_HANDLE ":CreateFile",
Zachary Waref2244ea2015-05-13 01:22:54 -0500150 &file_name, &desired_access, &share_mode, &security_attributes, &creation_disposition, &flags_and_attributes, &template_file))
151 goto exit;
152 _return_value = _winapi_CreateFile_impl(module, file_name, desired_access, share_mode, security_attributes, creation_disposition, flags_and_attributes, template_file);
153 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
154 goto exit;
155 if (_return_value == NULL)
156 Py_RETURN_NONE;
157 return_value = HANDLE_TO_PYNUM(_return_value);
158
159exit:
160 return return_value;
161}
162
163PyDoc_STRVAR(_winapi_CreateJunction__doc__,
164"CreateJunction($module, src_path, dst_path, /)\n"
165"--\n"
166"\n");
167
168#define _WINAPI_CREATEJUNCTION_METHODDEF \
169 {"CreateJunction", (PyCFunction)_winapi_CreateJunction, METH_VARARGS, _winapi_CreateJunction__doc__},
170
171static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500172_winapi_CreateJunction_impl(PyModuleDef *module, LPWSTR src_path,
173 LPWSTR dst_path);
Zachary Waref2244ea2015-05-13 01:22:54 -0500174
175static PyObject *
176_winapi_CreateJunction(PyModuleDef *module, PyObject *args)
177{
178 PyObject *return_value = NULL;
179 LPWSTR src_path;
180 LPWSTR dst_path;
181
Zachary Ware77772c02015-05-13 10:58:35 -0500182 if (!PyArg_ParseTuple(args, "uu:CreateJunction",
Zachary Waref2244ea2015-05-13 01:22:54 -0500183 &src_path, &dst_path))
184 goto exit;
185 return_value = _winapi_CreateJunction_impl(module, src_path, dst_path);
186
187exit:
188 return return_value;
189}
190
191PyDoc_STRVAR(_winapi_CreateNamedPipe__doc__,
192"CreateNamedPipe($module, name, open_mode, pipe_mode, max_instances,\n"
193" out_buffer_size, in_buffer_size, default_timeout,\n"
194" security_attributes, /)\n"
195"--\n"
196"\n");
197
198#define _WINAPI_CREATENAMEDPIPE_METHODDEF \
199 {"CreateNamedPipe", (PyCFunction)_winapi_CreateNamedPipe, METH_VARARGS, _winapi_CreateNamedPipe__doc__},
200
201static HANDLE
Zachary Ware77772c02015-05-13 10:58:35 -0500202_winapi_CreateNamedPipe_impl(PyModuleDef *module, LPCTSTR name,
203 DWORD open_mode, DWORD pipe_mode,
204 DWORD max_instances, DWORD out_buffer_size,
205 DWORD in_buffer_size, DWORD default_timeout,
206 LPSECURITY_ATTRIBUTES security_attributes);
Zachary Waref2244ea2015-05-13 01:22:54 -0500207
208static PyObject *
209_winapi_CreateNamedPipe(PyModuleDef *module, PyObject *args)
210{
211 PyObject *return_value = NULL;
212 LPCTSTR name;
213 DWORD open_mode;
214 DWORD pipe_mode;
215 DWORD max_instances;
216 DWORD out_buffer_size;
217 DWORD in_buffer_size;
218 DWORD default_timeout;
219 LPSECURITY_ATTRIBUTES security_attributes;
220 HANDLE _return_value;
221
Zachary Ware77772c02015-05-13 10:58:35 -0500222 if (!PyArg_ParseTuple(args, "skkkkkk" F_POINTER ":CreateNamedPipe",
Zachary Waref2244ea2015-05-13 01:22:54 -0500223 &name, &open_mode, &pipe_mode, &max_instances, &out_buffer_size, &in_buffer_size, &default_timeout, &security_attributes))
224 goto exit;
225 _return_value = _winapi_CreateNamedPipe_impl(module, name, open_mode, pipe_mode, max_instances, out_buffer_size, in_buffer_size, default_timeout, security_attributes);
226 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
227 goto exit;
228 if (_return_value == NULL)
229 Py_RETURN_NONE;
230 return_value = HANDLE_TO_PYNUM(_return_value);
231
232exit:
233 return return_value;
234}
235
236PyDoc_STRVAR(_winapi_CreatePipe__doc__,
237"CreatePipe($module, pipe_attrs, size, /)\n"
238"--\n"
239"\n"
240"Create an anonymous pipe.\n"
241"\n"
242" pipe_attrs\n"
243" Ignored internally, can be None.\n"
244"\n"
245"Returns a 2-tuple of handles, to the read and write ends of the pipe.");
246
247#define _WINAPI_CREATEPIPE_METHODDEF \
248 {"CreatePipe", (PyCFunction)_winapi_CreatePipe, METH_VARARGS, _winapi_CreatePipe__doc__},
249
250static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500251_winapi_CreatePipe_impl(PyModuleDef *module, PyObject *pipe_attrs,
252 DWORD size);
Zachary Waref2244ea2015-05-13 01:22:54 -0500253
254static PyObject *
255_winapi_CreatePipe(PyModuleDef *module, PyObject *args)
256{
257 PyObject *return_value = NULL;
258 PyObject *pipe_attrs;
259 DWORD size;
260
Zachary Ware77772c02015-05-13 10:58:35 -0500261 if (!PyArg_ParseTuple(args, "Ok:CreatePipe",
Zachary Waref2244ea2015-05-13 01:22:54 -0500262 &pipe_attrs, &size))
263 goto exit;
264 return_value = _winapi_CreatePipe_impl(module, pipe_attrs, size);
265
266exit:
267 return return_value;
268}
269
270PyDoc_STRVAR(_winapi_CreateProcess__doc__,
271"CreateProcess($module, application_name, command_line, proc_attrs,\n"
272" thread_attrs, inherit_handles, creation_flags,\n"
273" env_mapping, current_directory, startup_info, /)\n"
274"--\n"
275"\n"
276"Create a new process and its primary thread.\n"
277"\n"
278" proc_attrs\n"
279" Ignored internally, can be None.\n"
280" thread_attrs\n"
281" Ignored internally, can be None.\n"
282"\n"
283"The return value is a tuple of the process handle, thread handle,\n"
284"process ID, and thread ID.");
285
286#define _WINAPI_CREATEPROCESS_METHODDEF \
287 {"CreateProcess", (PyCFunction)_winapi_CreateProcess, METH_VARARGS, _winapi_CreateProcess__doc__},
288
289static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500290_winapi_CreateProcess_impl(PyModuleDef *module, Py_UNICODE *application_name,
291 Py_UNICODE *command_line, PyObject *proc_attrs,
292 PyObject *thread_attrs, BOOL inherit_handles,
293 DWORD creation_flags, PyObject *env_mapping,
294 Py_UNICODE *current_directory,
295 PyObject *startup_info);
Zachary Waref2244ea2015-05-13 01:22:54 -0500296
297static PyObject *
298_winapi_CreateProcess(PyModuleDef *module, PyObject *args)
299{
300 PyObject *return_value = NULL;
301 Py_UNICODE *application_name;
302 Py_UNICODE *command_line;
303 PyObject *proc_attrs;
304 PyObject *thread_attrs;
305 BOOL inherit_handles;
306 DWORD creation_flags;
307 PyObject *env_mapping;
308 Py_UNICODE *current_directory;
309 PyObject *startup_info;
310
Zachary Ware77772c02015-05-13 10:58:35 -0500311 if (!PyArg_ParseTuple(args, "ZZOOikOZO:CreateProcess",
Zachary Waref2244ea2015-05-13 01:22:54 -0500312 &application_name, &command_line, &proc_attrs, &thread_attrs, &inherit_handles, &creation_flags, &env_mapping, &current_directory, &startup_info))
313 goto exit;
314 return_value = _winapi_CreateProcess_impl(module, application_name, command_line, proc_attrs, thread_attrs, inherit_handles, creation_flags, env_mapping, current_directory, startup_info);
315
316exit:
317 return return_value;
318}
319
320PyDoc_STRVAR(_winapi_DuplicateHandle__doc__,
321"DuplicateHandle($module, source_process_handle, source_handle,\n"
322" target_process_handle, desired_access, inherit_handle,\n"
323" options=0, /)\n"
324"--\n"
325"\n"
326"Return a duplicate handle object.\n"
327"\n"
328"The duplicate handle refers to the same object as the original\n"
329"handle. Therefore, any changes to the object are reflected\n"
330"through both handles.");
331
332#define _WINAPI_DUPLICATEHANDLE_METHODDEF \
333 {"DuplicateHandle", (PyCFunction)_winapi_DuplicateHandle, METH_VARARGS, _winapi_DuplicateHandle__doc__},
334
335static HANDLE
Zachary Ware77772c02015-05-13 10:58:35 -0500336_winapi_DuplicateHandle_impl(PyModuleDef *module,
337 HANDLE source_process_handle,
338 HANDLE source_handle,
339 HANDLE target_process_handle,
340 DWORD desired_access, BOOL inherit_handle,
341 DWORD options);
Zachary Waref2244ea2015-05-13 01:22:54 -0500342
343static PyObject *
344_winapi_DuplicateHandle(PyModuleDef *module, PyObject *args)
345{
346 PyObject *return_value = NULL;
347 HANDLE source_process_handle;
348 HANDLE source_handle;
349 HANDLE target_process_handle;
350 DWORD desired_access;
351 BOOL inherit_handle;
352 DWORD options = 0;
353 HANDLE _return_value;
354
Zachary Ware77772c02015-05-13 10:58:35 -0500355 if (!PyArg_ParseTuple(args, "" F_HANDLE "" F_HANDLE "" F_HANDLE "ki|k:DuplicateHandle",
Zachary Waref2244ea2015-05-13 01:22:54 -0500356 &source_process_handle, &source_handle, &target_process_handle, &desired_access, &inherit_handle, &options))
357 goto exit;
358 _return_value = _winapi_DuplicateHandle_impl(module, source_process_handle, source_handle, target_process_handle, desired_access, inherit_handle, options);
359 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
360 goto exit;
361 if (_return_value == NULL)
362 Py_RETURN_NONE;
363 return_value = HANDLE_TO_PYNUM(_return_value);
364
365exit:
366 return return_value;
367}
368
369PyDoc_STRVAR(_winapi_ExitProcess__doc__,
370"ExitProcess($module, ExitCode, /)\n"
371"--\n"
372"\n");
373
374#define _WINAPI_EXITPROCESS_METHODDEF \
375 {"ExitProcess", (PyCFunction)_winapi_ExitProcess, METH_O, _winapi_ExitProcess__doc__},
376
377static PyObject *
378_winapi_ExitProcess_impl(PyModuleDef *module, UINT ExitCode);
379
380static PyObject *
381_winapi_ExitProcess(PyModuleDef *module, PyObject *arg)
382{
383 PyObject *return_value = NULL;
384 UINT ExitCode;
385
Zachary Ware77772c02015-05-13 10:58:35 -0500386 if (!PyArg_Parse(arg, "I:ExitProcess", &ExitCode))
Zachary Waref2244ea2015-05-13 01:22:54 -0500387 goto exit;
388 return_value = _winapi_ExitProcess_impl(module, ExitCode);
389
390exit:
391 return return_value;
392}
393
394PyDoc_STRVAR(_winapi_GetCurrentProcess__doc__,
395"GetCurrentProcess($module, /)\n"
396"--\n"
397"\n"
398"Return a handle object for the current process.");
399
400#define _WINAPI_GETCURRENTPROCESS_METHODDEF \
401 {"GetCurrentProcess", (PyCFunction)_winapi_GetCurrentProcess, METH_NOARGS, _winapi_GetCurrentProcess__doc__},
402
403static HANDLE
404_winapi_GetCurrentProcess_impl(PyModuleDef *module);
405
406static PyObject *
407_winapi_GetCurrentProcess(PyModuleDef *module, PyObject *Py_UNUSED(ignored))
408{
409 PyObject *return_value = NULL;
410 HANDLE _return_value;
411
412 _return_value = _winapi_GetCurrentProcess_impl(module);
413 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
414 goto exit;
415 if (_return_value == NULL)
416 Py_RETURN_NONE;
417 return_value = HANDLE_TO_PYNUM(_return_value);
418
419exit:
420 return return_value;
421}
422
423PyDoc_STRVAR(_winapi_GetExitCodeProcess__doc__,
424"GetExitCodeProcess($module, process, /)\n"
425"--\n"
426"\n"
427"Return the termination status of the specified process.");
428
429#define _WINAPI_GETEXITCODEPROCESS_METHODDEF \
430 {"GetExitCodeProcess", (PyCFunction)_winapi_GetExitCodeProcess, METH_O, _winapi_GetExitCodeProcess__doc__},
431
432static DWORD
433_winapi_GetExitCodeProcess_impl(PyModuleDef *module, HANDLE process);
434
435static PyObject *
436_winapi_GetExitCodeProcess(PyModuleDef *module, PyObject *arg)
437{
438 PyObject *return_value = NULL;
439 HANDLE process;
440 DWORD _return_value;
441
Zachary Ware77772c02015-05-13 10:58:35 -0500442 if (!PyArg_Parse(arg, "" F_HANDLE ":GetExitCodeProcess", &process))
Zachary Waref2244ea2015-05-13 01:22:54 -0500443 goto exit;
444 _return_value = _winapi_GetExitCodeProcess_impl(module, process);
445 if ((_return_value == DWORD_MAX) && PyErr_Occurred())
446 goto exit;
447 return_value = Py_BuildValue("k", _return_value);
448
449exit:
450 return return_value;
451}
452
453PyDoc_STRVAR(_winapi_GetLastError__doc__,
454"GetLastError($module, /)\n"
455"--\n"
456"\n");
457
458#define _WINAPI_GETLASTERROR_METHODDEF \
459 {"GetLastError", (PyCFunction)_winapi_GetLastError, METH_NOARGS, _winapi_GetLastError__doc__},
460
461static DWORD
462_winapi_GetLastError_impl(PyModuleDef *module);
463
464static PyObject *
465_winapi_GetLastError(PyModuleDef *module, PyObject *Py_UNUSED(ignored))
466{
467 PyObject *return_value = NULL;
468 DWORD _return_value;
469
470 _return_value = _winapi_GetLastError_impl(module);
471 if ((_return_value == DWORD_MAX) && PyErr_Occurred())
472 goto exit;
473 return_value = Py_BuildValue("k", _return_value);
474
475exit:
476 return return_value;
477}
478
479PyDoc_STRVAR(_winapi_GetModuleFileName__doc__,
480"GetModuleFileName($module, module_handle, /)\n"
481"--\n"
482"\n"
483"Return the fully-qualified path for the file that contains module.\n"
484"\n"
485"The module must have been loaded by the current process.\n"
486"\n"
487"The module parameter should be a handle to the loaded module\n"
488"whose path is being requested. If this parameter is 0,\n"
489"GetModuleFileName retrieves the path of the executable file\n"
490"of the current process.");
491
492#define _WINAPI_GETMODULEFILENAME_METHODDEF \
493 {"GetModuleFileName", (PyCFunction)_winapi_GetModuleFileName, METH_O, _winapi_GetModuleFileName__doc__},
494
495static PyObject *
496_winapi_GetModuleFileName_impl(PyModuleDef *module, HMODULE module_handle);
497
498static PyObject *
499_winapi_GetModuleFileName(PyModuleDef *module, PyObject *arg)
500{
501 PyObject *return_value = NULL;
502 HMODULE module_handle;
503
Zachary Ware77772c02015-05-13 10:58:35 -0500504 if (!PyArg_Parse(arg, "" F_HANDLE ":GetModuleFileName", &module_handle))
Zachary Waref2244ea2015-05-13 01:22:54 -0500505 goto exit;
506 return_value = _winapi_GetModuleFileName_impl(module, module_handle);
507
508exit:
509 return return_value;
510}
511
512PyDoc_STRVAR(_winapi_GetStdHandle__doc__,
513"GetStdHandle($module, std_handle, /)\n"
514"--\n"
515"\n"
516"Return a handle to the specified standard device.\n"
517"\n"
518" std_handle\n"
519" One of STD_INPUT_HANDLE, STD_OUTPUT_HANDLE, or STD_ERROR_HANDLE.\n"
520"\n"
521"The integer associated with the handle object is returned.");
522
523#define _WINAPI_GETSTDHANDLE_METHODDEF \
524 {"GetStdHandle", (PyCFunction)_winapi_GetStdHandle, METH_O, _winapi_GetStdHandle__doc__},
525
526static HANDLE
527_winapi_GetStdHandle_impl(PyModuleDef *module, DWORD std_handle);
528
529static PyObject *
530_winapi_GetStdHandle(PyModuleDef *module, PyObject *arg)
531{
532 PyObject *return_value = NULL;
533 DWORD std_handle;
534 HANDLE _return_value;
535
Zachary Ware77772c02015-05-13 10:58:35 -0500536 if (!PyArg_Parse(arg, "k:GetStdHandle", &std_handle))
Zachary Waref2244ea2015-05-13 01:22:54 -0500537 goto exit;
538 _return_value = _winapi_GetStdHandle_impl(module, std_handle);
539 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
540 goto exit;
541 if (_return_value == NULL)
542 Py_RETURN_NONE;
543 return_value = HANDLE_TO_PYNUM(_return_value);
544
545exit:
546 return return_value;
547}
548
549PyDoc_STRVAR(_winapi_GetVersion__doc__,
550"GetVersion($module, /)\n"
551"--\n"
552"\n"
553"Return the version number of the current operating system.");
554
555#define _WINAPI_GETVERSION_METHODDEF \
556 {"GetVersion", (PyCFunction)_winapi_GetVersion, METH_NOARGS, _winapi_GetVersion__doc__},
557
558static long
559_winapi_GetVersion_impl(PyModuleDef *module);
560
561static PyObject *
562_winapi_GetVersion(PyModuleDef *module, PyObject *Py_UNUSED(ignored))
563{
564 PyObject *return_value = NULL;
565 long _return_value;
566
567 _return_value = _winapi_GetVersion_impl(module);
568 if ((_return_value == -1) && PyErr_Occurred())
569 goto exit;
570 return_value = PyLong_FromLong(_return_value);
571
572exit:
573 return return_value;
574}
575
576PyDoc_STRVAR(_winapi_OpenProcess__doc__,
577"OpenProcess($module, desired_access, inherit_handle, process_id, /)\n"
578"--\n"
579"\n");
580
581#define _WINAPI_OPENPROCESS_METHODDEF \
582 {"OpenProcess", (PyCFunction)_winapi_OpenProcess, METH_VARARGS, _winapi_OpenProcess__doc__},
583
584static HANDLE
Zachary Ware77772c02015-05-13 10:58:35 -0500585_winapi_OpenProcess_impl(PyModuleDef *module, DWORD desired_access,
586 BOOL inherit_handle, DWORD process_id);
Zachary Waref2244ea2015-05-13 01:22:54 -0500587
588static PyObject *
589_winapi_OpenProcess(PyModuleDef *module, PyObject *args)
590{
591 PyObject *return_value = NULL;
592 DWORD desired_access;
593 BOOL inherit_handle;
594 DWORD process_id;
595 HANDLE _return_value;
596
Zachary Ware77772c02015-05-13 10:58:35 -0500597 if (!PyArg_ParseTuple(args, "kik:OpenProcess",
Zachary Waref2244ea2015-05-13 01:22:54 -0500598 &desired_access, &inherit_handle, &process_id))
599 goto exit;
600 _return_value = _winapi_OpenProcess_impl(module, desired_access, inherit_handle, process_id);
601 if ((_return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred())
602 goto exit;
603 if (_return_value == NULL)
604 Py_RETURN_NONE;
605 return_value = HANDLE_TO_PYNUM(_return_value);
606
607exit:
608 return return_value;
609}
610
611PyDoc_STRVAR(_winapi_PeekNamedPipe__doc__,
612"PeekNamedPipe($module, handle, size=0, /)\n"
613"--\n"
614"\n");
615
616#define _WINAPI_PEEKNAMEDPIPE_METHODDEF \
617 {"PeekNamedPipe", (PyCFunction)_winapi_PeekNamedPipe, METH_VARARGS, _winapi_PeekNamedPipe__doc__},
618
619static PyObject *
620_winapi_PeekNamedPipe_impl(PyModuleDef *module, HANDLE handle, int size);
621
622static PyObject *
623_winapi_PeekNamedPipe(PyModuleDef *module, PyObject *args)
624{
625 PyObject *return_value = NULL;
626 HANDLE handle;
627 int size = 0;
628
Zachary Ware77772c02015-05-13 10:58:35 -0500629 if (!PyArg_ParseTuple(args, "" F_HANDLE "|i:PeekNamedPipe",
Zachary Waref2244ea2015-05-13 01:22:54 -0500630 &handle, &size))
631 goto exit;
632 return_value = _winapi_PeekNamedPipe_impl(module, handle, size);
633
634exit:
635 return return_value;
636}
637
638PyDoc_STRVAR(_winapi_ReadFile__doc__,
639"ReadFile($module, /, handle, size, overlapped=False)\n"
640"--\n"
641"\n");
642
643#define _WINAPI_READFILE_METHODDEF \
644 {"ReadFile", (PyCFunction)_winapi_ReadFile, METH_VARARGS|METH_KEYWORDS, _winapi_ReadFile__doc__},
645
646static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500647_winapi_ReadFile_impl(PyModuleDef *module, HANDLE handle, int size,
648 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500649
650static PyObject *
651_winapi_ReadFile(PyModuleDef *module, PyObject *args, PyObject *kwargs)
652{
653 PyObject *return_value = NULL;
654 static char *_keywords[] = {"handle", "size", "overlapped", NULL};
655 HANDLE handle;
656 int size;
657 int use_overlapped = 0;
658
Zachary Ware77772c02015-05-13 10:58:35 -0500659 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "" F_HANDLE "i|i:ReadFile", _keywords,
Zachary Waref2244ea2015-05-13 01:22:54 -0500660 &handle, &size, &use_overlapped))
661 goto exit;
662 return_value = _winapi_ReadFile_impl(module, handle, size, use_overlapped);
663
664exit:
665 return return_value;
666}
667
668PyDoc_STRVAR(_winapi_SetNamedPipeHandleState__doc__,
669"SetNamedPipeHandleState($module, named_pipe, mode,\n"
670" max_collection_count, collect_data_timeout, /)\n"
671"--\n"
672"\n");
673
674#define _WINAPI_SETNAMEDPIPEHANDLESTATE_METHODDEF \
675 {"SetNamedPipeHandleState", (PyCFunction)_winapi_SetNamedPipeHandleState, METH_VARARGS, _winapi_SetNamedPipeHandleState__doc__},
676
677static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500678_winapi_SetNamedPipeHandleState_impl(PyModuleDef *module, HANDLE named_pipe,
679 PyObject *mode,
680 PyObject *max_collection_count,
681 PyObject *collect_data_timeout);
Zachary Waref2244ea2015-05-13 01:22:54 -0500682
683static PyObject *
684_winapi_SetNamedPipeHandleState(PyModuleDef *module, PyObject *args)
685{
686 PyObject *return_value = NULL;
687 HANDLE named_pipe;
688 PyObject *mode;
689 PyObject *max_collection_count;
690 PyObject *collect_data_timeout;
691
Zachary Ware77772c02015-05-13 10:58:35 -0500692 if (!PyArg_ParseTuple(args, "" F_HANDLE "OOO:SetNamedPipeHandleState",
Zachary Waref2244ea2015-05-13 01:22:54 -0500693 &named_pipe, &mode, &max_collection_count, &collect_data_timeout))
694 goto exit;
695 return_value = _winapi_SetNamedPipeHandleState_impl(module, named_pipe, mode, max_collection_count, collect_data_timeout);
696
697exit:
698 return return_value;
699}
700
701PyDoc_STRVAR(_winapi_TerminateProcess__doc__,
702"TerminateProcess($module, handle, exit_code, /)\n"
703"--\n"
704"\n"
705"Terminate the specified process and all of its threads.");
706
707#define _WINAPI_TERMINATEPROCESS_METHODDEF \
708 {"TerminateProcess", (PyCFunction)_winapi_TerminateProcess, METH_VARARGS, _winapi_TerminateProcess__doc__},
709
710static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500711_winapi_TerminateProcess_impl(PyModuleDef *module, HANDLE handle,
712 UINT exit_code);
Zachary Waref2244ea2015-05-13 01:22:54 -0500713
714static PyObject *
715_winapi_TerminateProcess(PyModuleDef *module, PyObject *args)
716{
717 PyObject *return_value = NULL;
718 HANDLE handle;
719 UINT exit_code;
720
Zachary Ware77772c02015-05-13 10:58:35 -0500721 if (!PyArg_ParseTuple(args, "" F_HANDLE "I:TerminateProcess",
Zachary Waref2244ea2015-05-13 01:22:54 -0500722 &handle, &exit_code))
723 goto exit;
724 return_value = _winapi_TerminateProcess_impl(module, handle, exit_code);
725
726exit:
727 return return_value;
728}
729
730PyDoc_STRVAR(_winapi_WaitNamedPipe__doc__,
731"WaitNamedPipe($module, name, timeout, /)\n"
732"--\n"
733"\n");
734
735#define _WINAPI_WAITNAMEDPIPE_METHODDEF \
736 {"WaitNamedPipe", (PyCFunction)_winapi_WaitNamedPipe, METH_VARARGS, _winapi_WaitNamedPipe__doc__},
737
738static PyObject *
739_winapi_WaitNamedPipe_impl(PyModuleDef *module, LPCTSTR name, DWORD timeout);
740
741static PyObject *
742_winapi_WaitNamedPipe(PyModuleDef *module, PyObject *args)
743{
744 PyObject *return_value = NULL;
745 LPCTSTR name;
746 DWORD timeout;
747
Zachary Ware77772c02015-05-13 10:58:35 -0500748 if (!PyArg_ParseTuple(args, "sk:WaitNamedPipe",
Zachary Waref2244ea2015-05-13 01:22:54 -0500749 &name, &timeout))
750 goto exit;
751 return_value = _winapi_WaitNamedPipe_impl(module, name, timeout);
752
753exit:
754 return return_value;
755}
756
757PyDoc_STRVAR(_winapi_WaitForMultipleObjects__doc__,
758"WaitForMultipleObjects($module, handle_seq, wait_flag,\n"
759" milliseconds=_winapi.INFINITE, /)\n"
760"--\n"
761"\n");
762
763#define _WINAPI_WAITFORMULTIPLEOBJECTS_METHODDEF \
764 {"WaitForMultipleObjects", (PyCFunction)_winapi_WaitForMultipleObjects, METH_VARARGS, _winapi_WaitForMultipleObjects__doc__},
765
766static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500767_winapi_WaitForMultipleObjects_impl(PyModuleDef *module,
768 PyObject *handle_seq, BOOL wait_flag,
769 DWORD milliseconds);
Zachary Waref2244ea2015-05-13 01:22:54 -0500770
771static PyObject *
772_winapi_WaitForMultipleObjects(PyModuleDef *module, PyObject *args)
773{
774 PyObject *return_value = NULL;
775 PyObject *handle_seq;
776 BOOL wait_flag;
777 DWORD milliseconds = INFINITE;
778
Zachary Ware77772c02015-05-13 10:58:35 -0500779 if (!PyArg_ParseTuple(args, "Oi|k:WaitForMultipleObjects",
Zachary Waref2244ea2015-05-13 01:22:54 -0500780 &handle_seq, &wait_flag, &milliseconds))
781 goto exit;
782 return_value = _winapi_WaitForMultipleObjects_impl(module, handle_seq, wait_flag, milliseconds);
783
784exit:
785 return return_value;
786}
787
788PyDoc_STRVAR(_winapi_WaitForSingleObject__doc__,
789"WaitForSingleObject($module, handle, milliseconds, /)\n"
790"--\n"
791"\n"
792"Wait for a single object.\n"
793"\n"
794"Wait until the specified object is in the signaled state or\n"
795"the time-out interval elapses. The timeout value is specified\n"
796"in milliseconds.");
797
798#define _WINAPI_WAITFORSINGLEOBJECT_METHODDEF \
799 {"WaitForSingleObject", (PyCFunction)_winapi_WaitForSingleObject, METH_VARARGS, _winapi_WaitForSingleObject__doc__},
800
801static long
Zachary Ware77772c02015-05-13 10:58:35 -0500802_winapi_WaitForSingleObject_impl(PyModuleDef *module, HANDLE handle,
803 DWORD milliseconds);
Zachary Waref2244ea2015-05-13 01:22:54 -0500804
805static PyObject *
806_winapi_WaitForSingleObject(PyModuleDef *module, PyObject *args)
807{
808 PyObject *return_value = NULL;
809 HANDLE handle;
810 DWORD milliseconds;
811 long _return_value;
812
Zachary Ware77772c02015-05-13 10:58:35 -0500813 if (!PyArg_ParseTuple(args, "" F_HANDLE "k:WaitForSingleObject",
Zachary Waref2244ea2015-05-13 01:22:54 -0500814 &handle, &milliseconds))
815 goto exit;
816 _return_value = _winapi_WaitForSingleObject_impl(module, handle, milliseconds);
817 if ((_return_value == -1) && PyErr_Occurred())
818 goto exit;
819 return_value = PyLong_FromLong(_return_value);
820
821exit:
822 return return_value;
823}
824
825PyDoc_STRVAR(_winapi_WriteFile__doc__,
826"WriteFile($module, /, handle, buffer, overlapped=False)\n"
827"--\n"
828"\n");
829
830#define _WINAPI_WRITEFILE_METHODDEF \
831 {"WriteFile", (PyCFunction)_winapi_WriteFile, METH_VARARGS|METH_KEYWORDS, _winapi_WriteFile__doc__},
832
833static PyObject *
Zachary Ware77772c02015-05-13 10:58:35 -0500834_winapi_WriteFile_impl(PyModuleDef *module, HANDLE handle, PyObject *buffer,
835 int use_overlapped);
Zachary Waref2244ea2015-05-13 01:22:54 -0500836
837static PyObject *
838_winapi_WriteFile(PyModuleDef *module, PyObject *args, PyObject *kwargs)
839{
840 PyObject *return_value = NULL;
841 static char *_keywords[] = {"handle", "buffer", "overlapped", NULL};
842 HANDLE handle;
843 PyObject *buffer;
844 int use_overlapped = 0;
845
Zachary Ware77772c02015-05-13 10:58:35 -0500846 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "" F_HANDLE "O|i:WriteFile", _keywords,
Zachary Waref2244ea2015-05-13 01:22:54 -0500847 &handle, &buffer, &use_overlapped))
848 goto exit;
849 return_value = _winapi_WriteFile_impl(module, handle, buffer, use_overlapped);
850
851exit:
852 return return_value;
853}
Zachary Ware77772c02015-05-13 10:58:35 -0500854/*[clinic end generated code: output=98771c6584056d19 input=a9049054013a1b77]*/