2015-05-13 03:22:32 -03:00
|
|
|
/*[clinic input]
|
|
|
|
preserve
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_heapmin__doc__,
|
|
|
|
"heapmin($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Minimize the malloc() heap.\n"
|
|
|
|
"\n"
|
|
|
|
"Force the malloc() heap to clean itself up and return unused blocks\n"
|
|
|
|
"to the operating system. On failure, this raises OSError.");
|
|
|
|
|
|
|
|
#define MSVCRT_HEAPMIN_METHODDEF \
|
|
|
|
{"heapmin", (PyCFunction)msvcrt_heapmin, METH_NOARGS, msvcrt_heapmin__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_heapmin_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_heapmin(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
return msvcrt_heapmin_impl(module);
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_locking__doc__,
|
|
|
|
"locking($module, fd, mode, nbytes, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Lock part of a file based on file descriptor fd from the C runtime.\n"
|
|
|
|
"\n"
|
2017-04-16 04:46:38 -03:00
|
|
|
"Raises OSError on failure. The locked region of the file extends from\n"
|
2015-05-13 03:22:32 -03:00
|
|
|
"the current file position for nbytes bytes, and may continue beyond\n"
|
|
|
|
"the end of the file. mode must be one of the LK_* constants listed\n"
|
|
|
|
"below. Multiple regions in a file may be locked at the same time, but\n"
|
|
|
|
"may not overlap. Adjacent regions are not merged; they must be unlocked\n"
|
|
|
|
"individually.");
|
|
|
|
|
|
|
|
#define MSVCRT_LOCKING_METHODDEF \
|
2018-11-27 05:27:36 -04:00
|
|
|
{"locking", (PyCFunction)(void(*)(void))msvcrt_locking, METH_FASTCALL, msvcrt_locking__doc__},
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_locking_impl(PyObject *module, int fd, int mode, long nbytes);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2017-12-15 07:11:11 -04:00
|
|
|
msvcrt_locking(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int fd;
|
|
|
|
int mode;
|
|
|
|
long nbytes;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("locking", nargs, 3, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[0])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
fd = _PyLong_AsInt(args[0]);
|
|
|
|
if (fd == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[1])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
mode = _PyLong_AsInt(args[1]);
|
|
|
|
if (mode == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[2])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
nbytes = PyLong_AsLong(args[2]);
|
|
|
|
if (nbytes == -1 && PyErr_Occurred()) {
|
2017-01-16 20:35:17 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_locking_impl(module, fd, mode, nbytes);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_setmode__doc__,
|
|
|
|
"setmode($module, fd, mode, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Set the line-end translation mode for the file descriptor fd.\n"
|
|
|
|
"\n"
|
|
|
|
"To set it to text mode, flags should be os.O_TEXT; for binary, it\n"
|
|
|
|
"should be os.O_BINARY.\n"
|
|
|
|
"\n"
|
|
|
|
"Return value is the previous mode.");
|
|
|
|
|
|
|
|
#define MSVCRT_SETMODE_METHODDEF \
|
2018-11-27 05:27:36 -04:00
|
|
|
{"setmode", (PyCFunction)(void(*)(void))msvcrt_setmode, METH_FASTCALL, msvcrt_setmode__doc__},
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static long
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_setmode_impl(PyObject *module, int fd, int flags);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2017-12-15 07:11:11 -04:00
|
|
|
msvcrt_setmode(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int fd;
|
|
|
|
int flags;
|
|
|
|
long _return_value;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("setmode", nargs, 2, 2)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[0])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
fd = _PyLong_AsInt(args[0]);
|
|
|
|
if (fd == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[1])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
flags = _PyLong_AsInt(args[1]);
|
|
|
|
if (flags == -1 && PyErr_Occurred()) {
|
2017-01-16 20:35:17 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_setmode_impl(module, fd, flags);
|
2016-06-09 10:16:06 -03:00
|
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = PyLong_FromLong(_return_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_open_osfhandle__doc__,
|
|
|
|
"open_osfhandle($module, handle, flags, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Create a C runtime file descriptor from the file handle handle.\n"
|
|
|
|
"\n"
|
|
|
|
"The flags parameter should be a bitwise OR of os.O_APPEND, os.O_RDONLY,\n"
|
|
|
|
"and os.O_TEXT. The returned file descriptor may be used as a parameter\n"
|
|
|
|
"to os.fdopen() to create a file object.");
|
|
|
|
|
|
|
|
#define MSVCRT_OPEN_OSFHANDLE_METHODDEF \
|
2018-11-27 05:27:36 -04:00
|
|
|
{"open_osfhandle", (PyCFunction)(void(*)(void))msvcrt_open_osfhandle, METH_FASTCALL, msvcrt_open_osfhandle__doc__},
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static long
|
2017-07-26 19:17:57 -03:00
|
|
|
msvcrt_open_osfhandle_impl(PyObject *module, void *handle, int flags);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2017-12-15 07:11:11 -04:00
|
|
|
msvcrt_open_osfhandle(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2017-07-26 19:17:57 -03:00
|
|
|
void *handle;
|
2015-05-13 03:22:32 -03:00
|
|
|
int flags;
|
|
|
|
long _return_value;
|
|
|
|
|
2017-07-27 00:15:18 -03:00
|
|
|
if (!_PyArg_ParseStack(args, nargs, ""_Py_PARSE_UINTPTR"i:open_osfhandle",
|
2017-06-10 01:51:48 -03:00
|
|
|
&handle, &flags)) {
|
2017-01-16 20:35:17 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_open_osfhandle_impl(module, handle, flags);
|
2016-06-09 10:16:06 -03:00
|
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = PyLong_FromLong(_return_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_get_osfhandle__doc__,
|
|
|
|
"get_osfhandle($module, fd, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Return the file handle for the file descriptor fd.\n"
|
|
|
|
"\n"
|
2017-04-16 04:46:38 -03:00
|
|
|
"Raises OSError if fd is not recognized.");
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
#define MSVCRT_GET_OSFHANDLE_METHODDEF \
|
|
|
|
{"get_osfhandle", (PyCFunction)msvcrt_get_osfhandle, METH_O, msvcrt_get_osfhandle__doc__},
|
|
|
|
|
2017-07-26 19:17:57 -03:00
|
|
|
static void *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_get_osfhandle_impl(PyObject *module, int fd);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_get_osfhandle(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int fd;
|
2017-07-26 19:17:57 -03:00
|
|
|
void *_return_value;
|
2015-05-13 03:22:32 -03:00
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyFloat_Check(arg)) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
fd = _PyLong_AsInt(arg);
|
|
|
|
if (fd == -1 && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_get_osfhandle_impl(module, fd);
|
2017-07-26 19:17:57 -03:00
|
|
|
if ((_return_value == NULL || _return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2017-07-26 19:17:57 -03:00
|
|
|
return_value = PyLong_FromVoidPtr(_return_value);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_kbhit__doc__,
|
|
|
|
"kbhit($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Return true if a keypress is waiting to be read.");
|
|
|
|
|
|
|
|
#define MSVCRT_KBHIT_METHODDEF \
|
|
|
|
{"kbhit", (PyCFunction)msvcrt_kbhit, METH_NOARGS, msvcrt_kbhit__doc__},
|
|
|
|
|
|
|
|
static long
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_kbhit_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_kbhit(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
long _return_value;
|
|
|
|
|
|
|
|
_return_value = msvcrt_kbhit_impl(module);
|
2016-06-09 10:16:06 -03:00
|
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = PyLong_FromLong(_return_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_getch__doc__,
|
|
|
|
"getch($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Read a keypress and return the resulting character as a byte string.\n"
|
|
|
|
"\n"
|
|
|
|
"Nothing is echoed to the console. This call will block if a keypress is\n"
|
|
|
|
"not already available, but will not wait for Enter to be pressed. If the\n"
|
|
|
|
"pressed key was a special function key, this will return \'\\000\' or\n"
|
|
|
|
"\'\\xe0\'; the next call will return the keycode. The Control-C keypress\n"
|
|
|
|
"cannot be read with this function.");
|
|
|
|
|
|
|
|
#define MSVCRT_GETCH_METHODDEF \
|
|
|
|
{"getch", (PyCFunction)msvcrt_getch, METH_NOARGS, msvcrt_getch__doc__},
|
|
|
|
|
|
|
|
static int
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getch_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getch(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char s[1];
|
|
|
|
|
|
|
|
s[0] = msvcrt_getch_impl(module);
|
|
|
|
return_value = PyBytes_FromStringAndSize(s, 1);
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_getwch__doc__,
|
|
|
|
"getwch($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wide char variant of getch(), returning a Unicode value.");
|
|
|
|
|
|
|
|
#define MSVCRT_GETWCH_METHODDEF \
|
|
|
|
{"getwch", (PyCFunction)msvcrt_getwch, METH_NOARGS, msvcrt_getwch__doc__},
|
|
|
|
|
|
|
|
static wchar_t
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getwch_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getwch(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
wchar_t _return_value;
|
|
|
|
|
|
|
|
_return_value = msvcrt_getwch_impl(module);
|
|
|
|
return_value = PyUnicode_FromOrdinal(_return_value);
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_getche__doc__,
|
|
|
|
"getche($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Similar to getch(), but the keypress will be echoed if possible.");
|
|
|
|
|
|
|
|
#define MSVCRT_GETCHE_METHODDEF \
|
|
|
|
{"getche", (PyCFunction)msvcrt_getche, METH_NOARGS, msvcrt_getche__doc__},
|
|
|
|
|
|
|
|
static int
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getche_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getche(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char s[1];
|
|
|
|
|
|
|
|
s[0] = msvcrt_getche_impl(module);
|
|
|
|
return_value = PyBytes_FromStringAndSize(s, 1);
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_getwche__doc__,
|
|
|
|
"getwche($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wide char variant of getche(), returning a Unicode value.");
|
|
|
|
|
|
|
|
#define MSVCRT_GETWCHE_METHODDEF \
|
|
|
|
{"getwche", (PyCFunction)msvcrt_getwche, METH_NOARGS, msvcrt_getwche__doc__},
|
|
|
|
|
|
|
|
static wchar_t
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getwche_impl(PyObject *module);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_getwche(PyObject *module, PyObject *Py_UNUSED(ignored))
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
wchar_t _return_value;
|
|
|
|
|
|
|
|
_return_value = msvcrt_getwche_impl(module);
|
|
|
|
return_value = PyUnicode_FromOrdinal(_return_value);
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_putch__doc__,
|
|
|
|
"putch($module, char, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Print the byte string char to the console without buffering.");
|
|
|
|
|
|
|
|
#define MSVCRT_PUTCH_METHODDEF \
|
|
|
|
{"putch", (PyCFunction)msvcrt_putch, METH_O, msvcrt_putch__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_putch_impl(PyObject *module, char char_value);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_putch(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char char_value;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyBytes_Check(arg) && PyBytes_GET_SIZE(arg) == 1) {
|
|
|
|
char_value = PyBytes_AS_STRING(arg)[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(arg) && PyByteArray_GET_SIZE(arg) == 1) {
|
|
|
|
char_value = PyByteArray_AS_STRING(arg)[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("putch", "argument", "a byte string of length 1", arg);
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_putch_impl(module, char_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_putwch__doc__,
|
|
|
|
"putwch($module, unicode_char, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wide char variant of putch(), accepting a Unicode value.");
|
|
|
|
|
|
|
|
#define MSVCRT_PUTWCH_METHODDEF \
|
|
|
|
{"putwch", (PyCFunction)msvcrt_putwch, METH_O, msvcrt_putwch__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_putwch_impl(PyObject *module, int unicode_char);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_putwch(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int unicode_char;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (!PyUnicode_Check(arg)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("putwch", "argument", "a unicode character", arg);
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyUnicode_READY(arg)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyUnicode_GET_LENGTH(arg) != 1) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("putwch", "argument", "a unicode character", arg);
|
2018-12-25 07:23:47 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
unicode_char = PyUnicode_READ_CHAR(arg, 0);
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_putwch_impl(module, unicode_char);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_ungetch__doc__,
|
|
|
|
"ungetch($module, char, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Opposite of getch.\n"
|
|
|
|
"\n"
|
|
|
|
"Cause the byte string char to be \"pushed back\" into the\n"
|
|
|
|
"console buffer; it will be the next character read by\n"
|
|
|
|
"getch() or getche().");
|
|
|
|
|
|
|
|
#define MSVCRT_UNGETCH_METHODDEF \
|
|
|
|
{"ungetch", (PyCFunction)msvcrt_ungetch, METH_O, msvcrt_ungetch__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_ungetch_impl(PyObject *module, char char_value);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_ungetch(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char char_value;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyBytes_Check(arg) && PyBytes_GET_SIZE(arg) == 1) {
|
|
|
|
char_value = PyBytes_AS_STRING(arg)[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(arg) && PyByteArray_GET_SIZE(arg) == 1) {
|
|
|
|
char_value = PyByteArray_AS_STRING(arg)[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("ungetch", "argument", "a byte string of length 1", arg);
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_ungetch_impl(module, char_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_ungetwch__doc__,
|
|
|
|
"ungetwch($module, unicode_char, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wide char variant of ungetch(), accepting a Unicode value.");
|
|
|
|
|
|
|
|
#define MSVCRT_UNGETWCH_METHODDEF \
|
|
|
|
{"ungetwch", (PyCFunction)msvcrt_ungetwch, METH_O, msvcrt_ungetwch__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_ungetwch_impl(PyObject *module, int unicode_char);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_ungetwch(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int unicode_char;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (!PyUnicode_Check(arg)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("ungetwch", "argument", "a unicode character", arg);
|
2018-12-25 07:23:47 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyUnicode_READY(arg)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyUnicode_GET_LENGTH(arg) != 1) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("ungetwch", "argument", "a unicode character", arg);
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2018-12-25 07:23:47 -04:00
|
|
|
unicode_char = PyUnicode_READ_CHAR(arg, 0);
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_ungetwch_impl(module, unicode_char);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if defined(_DEBUG)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_CrtSetReportFile__doc__,
|
|
|
|
"CrtSetReportFile($module, type, file, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wrapper around _CrtSetReportFile.\n"
|
|
|
|
"\n"
|
|
|
|
"Only available on Debug builds.");
|
|
|
|
|
|
|
|
#define MSVCRT_CRTSETREPORTFILE_METHODDEF \
|
2018-11-27 05:27:36 -04:00
|
|
|
{"CrtSetReportFile", (PyCFunction)(void(*)(void))msvcrt_CrtSetReportFile, METH_FASTCALL, msvcrt_CrtSetReportFile__doc__},
|
2015-05-13 03:22:32 -03:00
|
|
|
|
2017-07-26 19:17:57 -03:00
|
|
|
static void *
|
|
|
|
msvcrt_CrtSetReportFile_impl(PyObject *module, int type, void *file);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2017-12-15 07:11:11 -04:00
|
|
|
msvcrt_CrtSetReportFile(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int type;
|
2017-07-26 19:17:57 -03:00
|
|
|
void *file;
|
|
|
|
void *_return_value;
|
2015-05-13 03:22:32 -03:00
|
|
|
|
2017-07-27 00:15:18 -03:00
|
|
|
if (!_PyArg_ParseStack(args, nargs, "i"_Py_PARSE_UINTPTR":CrtSetReportFile",
|
2017-06-10 01:51:48 -03:00
|
|
|
&type, &file)) {
|
2017-01-16 20:35:17 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_CrtSetReportFile_impl(module, type, file);
|
2017-07-26 19:17:57 -03:00
|
|
|
if ((_return_value == NULL || _return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2017-07-26 19:17:57 -03:00
|
|
|
return_value = PyLong_FromVoidPtr(_return_value);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* defined(_DEBUG) */
|
|
|
|
|
|
|
|
#if defined(_DEBUG)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_CrtSetReportMode__doc__,
|
|
|
|
"CrtSetReportMode($module, type, mode, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wrapper around _CrtSetReportMode.\n"
|
|
|
|
"\n"
|
|
|
|
"Only available on Debug builds.");
|
|
|
|
|
|
|
|
#define MSVCRT_CRTSETREPORTMODE_METHODDEF \
|
2018-11-27 05:27:36 -04:00
|
|
|
{"CrtSetReportMode", (PyCFunction)(void(*)(void))msvcrt_CrtSetReportMode, METH_FASTCALL, msvcrt_CrtSetReportMode__doc__},
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static long
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_CrtSetReportMode_impl(PyObject *module, int type, int mode);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2017-12-15 07:11:11 -04:00
|
|
|
msvcrt_CrtSetReportMode(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int type;
|
|
|
|
int mode;
|
|
|
|
long _return_value;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("CrtSetReportMode", nargs, 2, 2)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[0])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
type = _PyLong_AsInt(args[0]);
|
|
|
|
if (type == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyFloat_Check(args[1])) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
mode = _PyLong_AsInt(args[1]);
|
|
|
|
if (mode == -1 && PyErr_Occurred()) {
|
2017-01-16 20:35:17 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_CrtSetReportMode_impl(module, type, mode);
|
2016-06-09 10:16:06 -03:00
|
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = PyLong_FromLong(_return_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* defined(_DEBUG) */
|
|
|
|
|
|
|
|
#if defined(_DEBUG)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_set_error_mode__doc__,
|
|
|
|
"set_error_mode($module, mode, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wrapper around _set_error_mode.\n"
|
|
|
|
"\n"
|
|
|
|
"Only available on Debug builds.");
|
|
|
|
|
|
|
|
#define MSVCRT_SET_ERROR_MODE_METHODDEF \
|
|
|
|
{"set_error_mode", (PyCFunction)msvcrt_set_error_mode, METH_O, msvcrt_set_error_mode__doc__},
|
|
|
|
|
|
|
|
static long
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_set_error_mode_impl(PyObject *module, int mode);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_set_error_mode(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int mode;
|
|
|
|
long _return_value;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyFloat_Check(arg)) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
mode = _PyLong_AsInt(arg);
|
|
|
|
if (mode == -1 && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
_return_value = msvcrt_set_error_mode_impl(module, mode);
|
2016-06-09 10:16:06 -03:00
|
|
|
if ((_return_value == -1) && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = PyLong_FromLong(_return_value);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* defined(_DEBUG) */
|
|
|
|
|
|
|
|
PyDoc_STRVAR(msvcrt_SetErrorMode__doc__,
|
|
|
|
"SetErrorMode($module, mode, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n"
|
|
|
|
"Wrapper around SetErrorMode.");
|
|
|
|
|
|
|
|
#define MSVCRT_SETERRORMODE_METHODDEF \
|
|
|
|
{"SetErrorMode", (PyCFunction)msvcrt_SetErrorMode, METH_O, msvcrt_SetErrorMode__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_SetErrorMode_impl(PyObject *module, unsigned int mode);
|
2015-05-13 03:22:32 -03:00
|
|
|
|
|
|
|
static PyObject *
|
2016-07-07 11:35:15 -03:00
|
|
|
msvcrt_SetErrorMode(PyObject *module, PyObject *arg)
|
2015-05-13 03:22:32 -03:00
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned int mode;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyFloat_Check(arg)) {
|
|
|
|
PyErr_SetString(PyExc_TypeError,
|
|
|
|
"integer argument expected, got float" );
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
mode = (unsigned int)PyLong_AsUnsignedLongMask(arg);
|
|
|
|
if (mode == (unsigned int)-1 && PyErr_Occurred()) {
|
2015-05-13 03:22:32 -03:00
|
|
|
goto exit;
|
2016-06-09 10:16:06 -03:00
|
|
|
}
|
2015-05-13 03:22:32 -03:00
|
|
|
return_value = msvcrt_SetErrorMode_impl(module, mode);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef MSVCRT_CRTSETREPORTFILE_METHODDEF
|
|
|
|
#define MSVCRT_CRTSETREPORTFILE_METHODDEF
|
|
|
|
#endif /* !defined(MSVCRT_CRTSETREPORTFILE_METHODDEF) */
|
|
|
|
|
|
|
|
#ifndef MSVCRT_CRTSETREPORTMODE_METHODDEF
|
|
|
|
#define MSVCRT_CRTSETREPORTMODE_METHODDEF
|
|
|
|
#endif /* !defined(MSVCRT_CRTSETREPORTMODE_METHODDEF) */
|
|
|
|
|
|
|
|
#ifndef MSVCRT_SET_ERROR_MODE_METHODDEF
|
|
|
|
#define MSVCRT_SET_ERROR_MODE_METHODDEF
|
|
|
|
#endif /* !defined(MSVCRT_SET_ERROR_MODE_METHODDEF) */
|
2019-08-29 11:49:08 -03:00
|
|
|
/*[clinic end generated code: output=7cc6ffaf64f268f7 input=a9049054013a1b77]*/
|