2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
output preset block
|
|
|
|
[clinic start generated code]*/
|
|
|
|
/*[clinic end generated code: output=da39a3ee5e6b4b0d input=3c81ac2402d06a8b]*/
|
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_object_converter
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object(converter="PyUnicode_FSConverter")
|
|
|
|
c: object(subclass_of="&PyUnicode_Type")
|
|
|
|
d: object(type="PyUnicode_Object *")
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_object_converter__doc__,
|
|
|
|
"test_object_converter($module, a, b, c, d, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_OBJECT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_object_converter", _PyCFunction_CAST(test_object_converter), METH_FASTCALL, test_object_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyUnicode_Object *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c;
|
|
|
|
PyUnicode_Object *d;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_object_converter", nargs, 4, 4)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
a = args[0];
|
|
|
|
if (!PyUnicode_FSConverter(args[1], &b)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (!PyUnicode_Check(args[2])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter", "argument 3", "str", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
d = (PyUnicode_Object *)args[3];
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_object_converter_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyUnicode_Object *d)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=886f4f9b598726b6 input=005e6a8a711a869b]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_object_converter_one_arg
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_object_converter_one_arg__doc__,
|
|
|
|
"test_object_converter_one_arg($module, a, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_OBJECT_CONVERTER_ONE_ARG_METHODDEF \
|
|
|
|
{"test_object_converter_one_arg", (PyCFunction)test_object_converter_one_arg, METH_O, test_object_converter_one_arg__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_one_arg(PyObject *module, PyObject *a)
|
|
|
|
/*[clinic end generated code: output=6da755f8502139df input=d635d92a421f1ca3]*/
|
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_objects_converter
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = NULL
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_objects_converter__doc__,
|
2019-09-14 06:24:05 -03:00
|
|
|
"test_objects_converter($module, a, b=<unrepresentable>, /)\n"
|
2018-12-25 04:17:28 -04:00
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_OBJECTS_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_objects_converter", _PyCFunction_CAST(test_objects_converter), METH_FASTCALL, test_objects_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_objects_converter_impl(PyObject *module, PyObject *a, PyObject *b);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_objects_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = NULL;
|
|
|
|
|
2019-01-11 12:01:42 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_objects_converter", nargs, 1, 2)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 12:01:42 -04:00
|
|
|
a = args[0];
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
b = args[1];
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_objects_converter_impl(module, a, b);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_objects_converter_impl(PyObject *module, PyObject *a, PyObject *b)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=fc26328b79d46bb7 input=4cbb3d9edd2a36f3]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_object_converter_subclass_of
|
|
|
|
|
|
|
|
a: object(subclass_of="&PyLong_Type")
|
|
|
|
b: object(subclass_of="&PyTuple_Type")
|
|
|
|
c: object(subclass_of="&PyList_Type")
|
|
|
|
d: object(subclass_of="&PySet_Type")
|
|
|
|
e: object(subclass_of="&PyFrozenSet_Type")
|
|
|
|
f: object(subclass_of="&PyDict_Type")
|
|
|
|
g: object(subclass_of="&PyUnicode_Type")
|
|
|
|
h: object(subclass_of="&PyBytes_Type")
|
|
|
|
i: object(subclass_of="&PyByteArray_Type")
|
|
|
|
j: object(subclass_of="&MyType")
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_object_converter_subclass_of__doc__,
|
|
|
|
"test_object_converter_subclass_of($module, a, b, c, d, e, f, g, h, i,\n"
|
|
|
|
" j, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_OBJECT_CONVERTER_SUBCLASS_OF_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_object_converter_subclass_of", _PyCFunction_CAST(test_object_converter_subclass_of), METH_FASTCALL, test_object_converter_subclass_of__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_subclass_of_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d,
|
|
|
|
PyObject *e, PyObject *f, PyObject *g,
|
|
|
|
PyObject *h, PyObject *i, PyObject *j);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_subclass_of(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c;
|
|
|
|
PyObject *d;
|
|
|
|
PyObject *e;
|
|
|
|
PyObject *f;
|
|
|
|
PyObject *g;
|
|
|
|
PyObject *h;
|
|
|
|
PyObject *i;
|
|
|
|
PyObject *j;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_object_converter_subclass_of", nargs, 10, 10)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (!PyLong_Check(args[0])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 1", "int", args[0]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!PyTuple_Check(args[1])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 2", "tuple", args[1]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
b = args[1];
|
|
|
|
if (!PyList_Check(args[2])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 3", "list", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
if (!PySet_Check(args[3])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 4", "set", args[3]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
if (!PyFrozenSet_Check(args[4])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 5", "frozenset", args[4]);
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
e = args[4];
|
|
|
|
if (!PyDict_Check(args[5])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 6", "dict", args[5]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
f = args[5];
|
|
|
|
if (!PyUnicode_Check(args[6])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 7", "str", args[6]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
g = args[6];
|
|
|
|
if (!PyBytes_Check(args[7])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 8", "bytes", args[7]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
h = args[7];
|
|
|
|
if (!PyByteArray_Check(args[8])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 9", "bytearray", args[8]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
i = args[8];
|
|
|
|
if (!PyObject_TypeCheck(args[9], &MyType)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_object_converter_subclass_of", "argument 10", (&MyType)->tp_name, args[9]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
j = args[9];
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_object_converter_subclass_of_impl(module, a, b, c, d, e, f, g, h, i, j);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_object_converter_subclass_of_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d,
|
|
|
|
PyObject *e, PyObject *f, PyObject *g,
|
|
|
|
PyObject *h, PyObject *i, PyObject *j)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=e4b07c9a54479a40 input=31b06b772d5f983e]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_PyBytesObject_converter
|
|
|
|
|
|
|
|
a: PyBytesObject
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_PyBytesObject_converter__doc__,
|
|
|
|
"test_PyBytesObject_converter($module, a, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PYBYTESOBJECT_CONVERTER_METHODDEF \
|
|
|
|
{"test_PyBytesObject_converter", (PyCFunction)test_PyBytesObject_converter, METH_O, test_PyBytesObject_converter__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyBytesObject_converter_impl(PyObject *module, PyBytesObject *a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyBytesObject_converter(PyObject *module, PyObject *arg)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyBytesObject *a;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (!PyBytes_Check(arg)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_PyBytesObject_converter", "argument", "bytes", arg);
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2018-12-25 07:23:47 -04:00
|
|
|
a = (PyBytesObject *)arg;
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_PyBytesObject_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyBytesObject_converter_impl(PyObject *module, PyBytesObject *a)
|
2019-08-29 11:49:08 -03:00
|
|
|
/*[clinic end generated code: output=7539d628e6fceace input=12b10c7cb5750400]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_PyByteArrayObject_converter
|
|
|
|
|
|
|
|
a: PyByteArrayObject
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_PyByteArrayObject_converter__doc__,
|
|
|
|
"test_PyByteArrayObject_converter($module, a, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PYBYTEARRAYOBJECT_CONVERTER_METHODDEF \
|
|
|
|
{"test_PyByteArrayObject_converter", (PyCFunction)test_PyByteArrayObject_converter, METH_O, test_PyByteArrayObject_converter__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyByteArrayObject_converter_impl(PyObject *module, PyByteArrayObject *a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyByteArrayObject_converter(PyObject *module, PyObject *arg)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyByteArrayObject *a;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (!PyByteArray_Check(arg)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_PyByteArrayObject_converter", "argument", "bytearray", arg);
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2018-12-25 07:23:47 -04:00
|
|
|
a = (PyByteArrayObject *)arg;
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_PyByteArrayObject_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_PyByteArrayObject_converter_impl(PyObject *module, PyByteArrayObject *a)
|
2019-08-29 11:49:08 -03:00
|
|
|
/*[clinic end generated code: output=1245af9f5b3e355e input=5a657da535d194ae]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unicode_converter
|
|
|
|
|
|
|
|
a: unicode
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unicode_converter__doc__,
|
|
|
|
"test_unicode_converter($module, a, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNICODE_CONVERTER_METHODDEF \
|
|
|
|
{"test_unicode_converter", (PyCFunction)test_unicode_converter, METH_O, test_unicode_converter__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unicode_converter_impl(PyObject *module, PyObject *a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unicode_converter(PyObject *module, PyObject *arg)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyObject *a;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
if (!PyUnicode_Check(arg)) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_unicode_converter", "argument", "str", arg);
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2018-12-25 07:23:47 -04:00
|
|
|
if (PyUnicode_READY(arg) == -1) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = arg;
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unicode_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unicode_converter_impl(PyObject *module, PyObject *a)
|
2019-08-29 11:49:08 -03:00
|
|
|
/*[clinic end generated code: output=18f1e3880c862611 input=aa33612df92aa9c5]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_bool_converter
|
|
|
|
|
|
|
|
a: bool = True
|
|
|
|
b: bool(accept={object}) = True
|
|
|
|
c: bool(accept={int}) = True
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_bool_converter__doc__,
|
|
|
|
"test_bool_converter($module, a=True, b=True, c=True, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_BOOL_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_bool_converter", _PyCFunction_CAST(test_bool_converter), METH_FASTCALL, test_bool_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_bool_converter_impl(PyObject *module, int a, int b, int c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_bool_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int a = 1;
|
|
|
|
int b = 1;
|
|
|
|
int c = 1;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_bool_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
a = PyObject_IsTrue(args[0]);
|
|
|
|
if (a < 0) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
b = PyObject_IsTrue(args[1]);
|
|
|
|
if (b < 0) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
c = _PyLong_AsInt(args[2]);
|
|
|
|
if (c == -1 && PyErr_Occurred()) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_bool_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_bool_converter_impl(PyObject *module, int a, int b, int c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=27f0e653a70b9be3 input=939854fa9f248c60]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_char_converter
|
|
|
|
|
|
|
|
a: char = b'A'
|
|
|
|
b: char = b'\a'
|
|
|
|
c: char = b'\b'
|
|
|
|
d: char = b'\t'
|
|
|
|
e: char = b'\n'
|
|
|
|
f: char = b'\v'
|
|
|
|
g: char = b'\f'
|
|
|
|
h: char = b'\r'
|
|
|
|
i: char = b'"'
|
|
|
|
j: char = b"'"
|
|
|
|
k: char = b'?'
|
|
|
|
l: char = b'\\'
|
|
|
|
m: char = b'\000'
|
2018-12-25 05:10:05 -04:00
|
|
|
n: char = b'\377'
|
2018-12-25 04:17:28 -04:00
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_char_converter__doc__,
|
|
|
|
"test_char_converter($module, a=b\'A\', b=b\'\\x07\', c=b\'\\x08\', d=b\'\\t\',\n"
|
|
|
|
" e=b\'\\n\', f=b\'\\x0b\', g=b\'\\x0c\', h=b\'\\r\', i=b\'\"\',\n"
|
2018-12-25 05:10:05 -04:00
|
|
|
" j=b\"\'\", k=b\'?\', l=b\'\\\\\', m=b\'\\x00\', n=b\'\\xff\', /)\n"
|
2018-12-25 04:17:28 -04:00
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_CHAR_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_char_converter", _PyCFunction_CAST(test_char_converter), METH_FASTCALL, test_char_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_char_converter_impl(PyObject *module, char a, char b, char c, char d,
|
|
|
|
char e, char f, char g, char h, char i, char j,
|
2018-12-25 05:10:05 -04:00
|
|
|
char k, char l, char m, char n);
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_char_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char a = 'A';
|
2018-12-25 05:10:05 -04:00
|
|
|
char b = '\x07';
|
|
|
|
char c = '\x08';
|
2018-12-25 04:17:28 -04:00
|
|
|
char d = '\t';
|
|
|
|
char e = '\n';
|
2018-12-25 05:10:05 -04:00
|
|
|
char f = '\x0b';
|
|
|
|
char g = '\x0c';
|
2018-12-25 04:17:28 -04:00
|
|
|
char h = '\r';
|
2018-12-25 05:10:05 -04:00
|
|
|
char i = '"';
|
2018-12-25 04:17:28 -04:00
|
|
|
char j = '\'';
|
2018-12-25 05:10:05 -04:00
|
|
|
char k = '?';
|
2018-12-25 04:17:28 -04:00
|
|
|
char l = '\\';
|
2018-12-25 05:10:05 -04:00
|
|
|
char m = '\x00';
|
|
|
|
char n = '\xff';
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_char_converter", nargs, 0, 14)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[0]) && PyBytes_GET_SIZE(args[0]) == 1) {
|
|
|
|
a = PyBytes_AS_STRING(args[0])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[0]) && PyByteArray_GET_SIZE(args[0]) == 1) {
|
|
|
|
a = PyByteArray_AS_STRING(args[0])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 1", "a byte string of length 1", args[0]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[1]) && PyBytes_GET_SIZE(args[1]) == 1) {
|
|
|
|
b = PyBytes_AS_STRING(args[1])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[1]) && PyByteArray_GET_SIZE(args[1]) == 1) {
|
|
|
|
b = PyByteArray_AS_STRING(args[1])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 2", "a byte string of length 1", args[1]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[2]) && PyBytes_GET_SIZE(args[2]) == 1) {
|
|
|
|
c = PyBytes_AS_STRING(args[2])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[2]) && PyByteArray_GET_SIZE(args[2]) == 1) {
|
|
|
|
c = PyByteArray_AS_STRING(args[2])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 3", "a byte string of length 1", args[2]);
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 4) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[3]) && PyBytes_GET_SIZE(args[3]) == 1) {
|
|
|
|
d = PyBytes_AS_STRING(args[3])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[3]) && PyByteArray_GET_SIZE(args[3]) == 1) {
|
|
|
|
d = PyByteArray_AS_STRING(args[3])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 4", "a byte string of length 1", args[3]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 5) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[4]) && PyBytes_GET_SIZE(args[4]) == 1) {
|
|
|
|
e = PyBytes_AS_STRING(args[4])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[4]) && PyByteArray_GET_SIZE(args[4]) == 1) {
|
|
|
|
e = PyByteArray_AS_STRING(args[4])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 5", "a byte string of length 1", args[4]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 6) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[5]) && PyBytes_GET_SIZE(args[5]) == 1) {
|
|
|
|
f = PyBytes_AS_STRING(args[5])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[5]) && PyByteArray_GET_SIZE(args[5]) == 1) {
|
|
|
|
f = PyByteArray_AS_STRING(args[5])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 6", "a byte string of length 1", args[5]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 7) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[6]) && PyBytes_GET_SIZE(args[6]) == 1) {
|
|
|
|
g = PyBytes_AS_STRING(args[6])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[6]) && PyByteArray_GET_SIZE(args[6]) == 1) {
|
|
|
|
g = PyByteArray_AS_STRING(args[6])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 7", "a byte string of length 1", args[6]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 8) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[7]) && PyBytes_GET_SIZE(args[7]) == 1) {
|
|
|
|
h = PyBytes_AS_STRING(args[7])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[7]) && PyByteArray_GET_SIZE(args[7]) == 1) {
|
|
|
|
h = PyByteArray_AS_STRING(args[7])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 8", "a byte string of length 1", args[7]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 9) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[8]) && PyBytes_GET_SIZE(args[8]) == 1) {
|
|
|
|
i = PyBytes_AS_STRING(args[8])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[8]) && PyByteArray_GET_SIZE(args[8]) == 1) {
|
|
|
|
i = PyByteArray_AS_STRING(args[8])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 9", "a byte string of length 1", args[8]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 10) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[9]) && PyBytes_GET_SIZE(args[9]) == 1) {
|
|
|
|
j = PyBytes_AS_STRING(args[9])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[9]) && PyByteArray_GET_SIZE(args[9]) == 1) {
|
|
|
|
j = PyByteArray_AS_STRING(args[9])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 10", "a byte string of length 1", args[9]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 11) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[10]) && PyBytes_GET_SIZE(args[10]) == 1) {
|
|
|
|
k = PyBytes_AS_STRING(args[10])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[10]) && PyByteArray_GET_SIZE(args[10]) == 1) {
|
|
|
|
k = PyByteArray_AS_STRING(args[10])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 11", "a byte string of length 1", args[10]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 12) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[11]) && PyBytes_GET_SIZE(args[11]) == 1) {
|
|
|
|
l = PyBytes_AS_STRING(args[11])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[11]) && PyByteArray_GET_SIZE(args[11]) == 1) {
|
|
|
|
l = PyByteArray_AS_STRING(args[11])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 12", "a byte string of length 1", args[11]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 13) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[12]) && PyBytes_GET_SIZE(args[12]) == 1) {
|
|
|
|
m = PyBytes_AS_STRING(args[12])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[12]) && PyByteArray_GET_SIZE(args[12]) == 1) {
|
|
|
|
m = PyByteArray_AS_STRING(args[12])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 13", "a byte string of length 1", args[12]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 14) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (PyBytes_Check(args[13]) && PyBytes_GET_SIZE(args[13]) == 1) {
|
|
|
|
n = PyBytes_AS_STRING(args[13])[0];
|
|
|
|
}
|
|
|
|
else if (PyByteArray_Check(args[13]) && PyByteArray_GET_SIZE(args[13]) == 1) {
|
|
|
|
n = PyByteArray_AS_STRING(args[13])[0];
|
|
|
|
}
|
|
|
|
else {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_char_converter", "argument 14", "a byte string of length 1", args[13]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 05:10:05 -04:00
|
|
|
return_value = test_char_converter_impl(module, a, b, c, d, e, f, g, h, i, j, k, l, m, n);
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_char_converter_impl(PyObject *module, char a, char b, char c, char d,
|
|
|
|
char e, char f, char g, char h, char i, char j,
|
2018-12-25 05:10:05 -04:00
|
|
|
char k, char l, char m, char n)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=98589f02422fe6b1 input=e42330417a44feac]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unsigned_char_converter
|
|
|
|
|
|
|
|
a: unsigned_char = 12
|
|
|
|
b: unsigned_char(bitwise=False) = 34
|
|
|
|
c: unsigned_char(bitwise=True) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unsigned_char_converter__doc__,
|
|
|
|
"test_unsigned_char_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNSIGNED_CHAR_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_unsigned_char_converter", _PyCFunction_CAST(test_unsigned_char_converter), METH_FASTCALL, test_unsigned_char_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_char_converter_impl(PyObject *module, unsigned char a,
|
|
|
|
unsigned char b, unsigned char c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_char_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned char a = 12;
|
|
|
|
unsigned char b = 34;
|
|
|
|
unsigned char c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_unsigned_char_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
long ival = PyLong_AsLong(args[0]);
|
|
|
|
if (ival == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival < 0) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"unsigned byte integer is less than minimum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival > UCHAR_MAX) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"unsigned byte integer is greater than maximum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
a = (unsigned char) ival;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
long ival = PyLong_AsLong(args[1]);
|
|
|
|
if (ival == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival < 0) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"unsigned byte integer is less than minimum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival > UCHAR_MAX) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"unsigned byte integer is greater than maximum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
b = (unsigned char) ival;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
2020-05-26 12:43:38 -03:00
|
|
|
unsigned long ival = PyLong_AsUnsignedLongMask(args[2]);
|
|
|
|
if (ival == (unsigned long)-1 && PyErr_Occurred()) {
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
c = (unsigned char) ival;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unsigned_char_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_char_converter_impl(PyObject *module, unsigned char a,
|
|
|
|
unsigned char b, unsigned char c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=45920dbedc22eb55 input=021414060993e289]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_short_converter
|
|
|
|
|
|
|
|
a: short = 12
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_short_converter__doc__,
|
|
|
|
"test_short_converter($module, a=12, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_SHORT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_short_converter", _PyCFunction_CAST(test_short_converter), METH_FASTCALL, test_short_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_short_converter_impl(PyObject *module, short a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_short_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
short a = 12;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_short_converter", nargs, 0, 1)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
long ival = PyLong_AsLong(args[0]);
|
|
|
|
if (ival == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival < SHRT_MIN) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"signed short integer is less than minimum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else if (ival > SHRT_MAX) {
|
|
|
|
PyErr_SetString(PyExc_OverflowError,
|
|
|
|
"signed short integer is greater than maximum");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
a = (short) ival;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_short_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_short_converter_impl(PyObject *module, short a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=a580945bd6963d45 input=6a8a7a509a498ff4]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unsigned_short_converter
|
|
|
|
|
|
|
|
a: unsigned_short = 12
|
|
|
|
b: unsigned_short(bitwise=False) = 34
|
|
|
|
c: unsigned_short(bitwise=True) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unsigned_short_converter__doc__,
|
|
|
|
"test_unsigned_short_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNSIGNED_SHORT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_unsigned_short_converter", _PyCFunction_CAST(test_unsigned_short_converter), METH_FASTCALL, test_unsigned_short_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_short_converter_impl(PyObject *module, unsigned short a,
|
|
|
|
unsigned short b, unsigned short c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_short_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned short a = 12;
|
|
|
|
unsigned short b = 34;
|
|
|
|
unsigned short c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_unsigned_short_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedShort_Converter(args[0], &a)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedShort_Converter(args[1], &b)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
c = (unsigned short)PyLong_AsUnsignedLongMask(args[2]);
|
|
|
|
if (c == (unsigned short)-1 && PyErr_Occurred()) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unsigned_short_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_short_converter_impl(PyObject *module, unsigned short a,
|
|
|
|
unsigned short b, unsigned short c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=e6e990df729114fc input=cdfd8eff3d9176b4]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_int_converter
|
|
|
|
|
|
|
|
a: int = 12
|
|
|
|
b: int(accept={int}) = 34
|
|
|
|
c: int(accept={str}) = 45
|
|
|
|
d: int(type='myenum') = 67
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_int_converter__doc__,
|
|
|
|
"test_int_converter($module, a=12, b=34, c=45, d=67, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_INT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_int_converter", _PyCFunction_CAST(test_int_converter), METH_FASTCALL, test_int_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_int_converter_impl(PyObject *module, int a, int b, int c, myenum d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_int_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
int a = 12;
|
|
|
|
int b = 34;
|
|
|
|
int c = 45;
|
|
|
|
myenum d = 67;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_int_converter", nargs, 0, 4)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
a = _PyLong_AsInt(args[0]);
|
|
|
|
if (a == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
b = _PyLong_AsInt(args[1]);
|
|
|
|
if (b == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!PyUnicode_Check(args[2])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_int_converter", "argument 3", "a unicode character", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyUnicode_READY(args[2])) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (PyUnicode_GET_LENGTH(args[2]) != 1) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_int_converter", "argument 3", "a unicode character", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
c = PyUnicode_READ_CHAR(args[2], 0);
|
|
|
|
if (nargs < 4) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
d = _PyLong_AsInt(args[3]);
|
|
|
|
if (d == -1 && PyErr_Occurred()) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_int_converter_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_int_converter_impl(PyObject *module, int a, int b, int c, myenum d)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=800993036e078c07 input=d20541fc1ca0553e]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unsigned_int_converter
|
|
|
|
|
|
|
|
a: unsigned_int = 12
|
|
|
|
b: unsigned_int(bitwise=False) = 34
|
|
|
|
c: unsigned_int(bitwise=True) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unsigned_int_converter__doc__,
|
|
|
|
"test_unsigned_int_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNSIGNED_INT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_unsigned_int_converter", _PyCFunction_CAST(test_unsigned_int_converter), METH_FASTCALL, test_unsigned_int_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_int_converter_impl(PyObject *module, unsigned int a,
|
|
|
|
unsigned int b, unsigned int c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_int_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned int a = 12;
|
|
|
|
unsigned int b = 34;
|
|
|
|
unsigned int c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_unsigned_int_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedInt_Converter(args[0], &a)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedInt_Converter(args[1], &b)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
c = (unsigned int)PyLong_AsUnsignedLongMask(args[2]);
|
|
|
|
if (c == (unsigned int)-1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unsigned_int_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_int_converter_impl(PyObject *module, unsigned int a,
|
|
|
|
unsigned int b, unsigned int c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=f9cdbe410ccc98a3 input=5533534828b62fc0]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_long_converter
|
|
|
|
|
|
|
|
a: long = 12
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_long_converter__doc__,
|
|
|
|
"test_long_converter($module, a=12, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_LONG_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_long_converter", _PyCFunction_CAST(test_long_converter), METH_FASTCALL, test_long_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_converter_impl(PyObject *module, long a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
long a = 12;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_long_converter", nargs, 0, 1)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
a = PyLong_AsLong(args[0]);
|
|
|
|
if (a == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_long_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_converter_impl(PyObject *module, long a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=02b3a83495c1d236 input=d2179e3c9cdcde89]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unsigned_long_converter
|
|
|
|
|
|
|
|
a: unsigned_long = 12
|
|
|
|
b: unsigned_long(bitwise=False) = 34
|
|
|
|
c: unsigned_long(bitwise=True) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unsigned_long_converter__doc__,
|
|
|
|
"test_unsigned_long_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNSIGNED_LONG_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_unsigned_long_converter", _PyCFunction_CAST(test_unsigned_long_converter), METH_FASTCALL, test_unsigned_long_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_converter_impl(PyObject *module, unsigned long a,
|
|
|
|
unsigned long b, unsigned long c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned long a = 12;
|
|
|
|
unsigned long b = 34;
|
|
|
|
unsigned long c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_unsigned_long_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedLong_Converter(args[0], &a)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedLong_Converter(args[1], &b)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!PyLong_Check(args[2])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_unsigned_long_converter", "argument 3", "int", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
c = PyLong_AsUnsignedLongMask(args[2]);
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unsigned_long_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_converter_impl(PyObject *module, unsigned long a,
|
|
|
|
unsigned long b, unsigned long c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=540bb0ba2894e1fe input=f450d94cae1ef73b]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_long_long_converter
|
|
|
|
|
|
|
|
a: long_long = 12
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_long_long_converter__doc__,
|
|
|
|
"test_long_long_converter($module, a=12, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_LONG_LONG_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_long_long_converter", _PyCFunction_CAST(test_long_long_converter), METH_FASTCALL, test_long_long_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_long_converter_impl(PyObject *module, long long a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_long_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
long long a = 12;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_long_long_converter", nargs, 0, 1)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
a = PyLong_AsLongLong(args[0]);
|
2019-10-21 03:49:48 -03:00
|
|
|
if (a == -1 && PyErr_Occurred()) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_long_long_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_long_long_converter_impl(PyObject *module, long long a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=f9d4ed79ad2db857 input=d5fc81577ff4dd02]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_unsigned_long_long_converter
|
|
|
|
|
|
|
|
a: unsigned_long_long = 12
|
|
|
|
b: unsigned_long_long(bitwise=False) = 34
|
|
|
|
c: unsigned_long_long(bitwise=True) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_unsigned_long_long_converter__doc__,
|
|
|
|
"test_unsigned_long_long_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_UNSIGNED_LONG_LONG_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_unsigned_long_long_converter", _PyCFunction_CAST(test_unsigned_long_long_converter), METH_FASTCALL, test_unsigned_long_long_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_long_converter_impl(PyObject *module,
|
|
|
|
unsigned long long a,
|
|
|
|
unsigned long long b,
|
|
|
|
unsigned long long c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_long_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
unsigned long long a = 12;
|
|
|
|
unsigned long long b = 34;
|
|
|
|
unsigned long long c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_unsigned_long_long_converter", nargs, 0, 3)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedLongLong_Converter(args[0], &a)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_UnsignedLongLong_Converter(args[1], &b)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!PyLong_Check(args[2])) {
|
2019-08-29 11:49:08 -03:00
|
|
|
_PyArg_BadArgument("test_unsigned_long_long_converter", "argument 3", "int", args[2]);
|
2019-01-11 10:01:14 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
c = PyLong_AsUnsignedLongLongMask(args[2]);
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_unsigned_long_long_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_unsigned_long_long_converter_impl(PyObject *module,
|
|
|
|
unsigned long long a,
|
|
|
|
unsigned long long b,
|
|
|
|
unsigned long long c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=3d69994f618b46bb input=a15115dc41866ff4]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_Py_ssize_t_converter
|
|
|
|
|
|
|
|
a: Py_ssize_t = 12
|
|
|
|
b: Py_ssize_t(accept={int}) = 34
|
|
|
|
c: Py_ssize_t(accept={int, NoneType}) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_Py_ssize_t_converter__doc__,
|
|
|
|
"test_Py_ssize_t_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PY_SSIZE_T_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_Py_ssize_t_converter", _PyCFunction_CAST(test_Py_ssize_t_converter), METH_FASTCALL, test_Py_ssize_t_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_ssize_t_converter_impl(PyObject *module, Py_ssize_t a, Py_ssize_t b,
|
|
|
|
Py_ssize_t c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_ssize_t_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
Py_ssize_t a = 12;
|
|
|
|
Py_ssize_t b = 34;
|
|
|
|
Py_ssize_t c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_Py_ssize_t_converter", nargs, 0, 3)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
Py_ssize_t ival = -1;
|
2020-05-28 04:33:45 -03:00
|
|
|
PyObject *iobj = _PyNumber_Index(args[0]);
|
2019-01-11 10:01:14 -04:00
|
|
|
if (iobj != NULL) {
|
|
|
|
ival = PyLong_AsSsize_t(iobj);
|
|
|
|
Py_DECREF(iobj);
|
|
|
|
}
|
|
|
|
if (ival == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = ival;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
{
|
|
|
|
Py_ssize_t ival = -1;
|
2020-05-28 04:33:45 -03:00
|
|
|
PyObject *iobj = _PyNumber_Index(args[1]);
|
2019-01-11 10:01:14 -04:00
|
|
|
if (iobj != NULL) {
|
|
|
|
ival = PyLong_AsSsize_t(iobj);
|
|
|
|
Py_DECREF(iobj);
|
|
|
|
}
|
|
|
|
if (ival == -1 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
b = ival;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_Py_convert_optional_to_ssize_t(args[2], &c)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_Py_ssize_t_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_ssize_t_converter_impl(PyObject *module, Py_ssize_t a, Py_ssize_t b,
|
|
|
|
Py_ssize_t c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=48214bc3d01f4dd7 input=3855f184bb3f299d]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_slice_index_converter
|
|
|
|
|
|
|
|
a: slice_index = 12
|
|
|
|
b: slice_index(accept={int}) = 34
|
|
|
|
c: slice_index(accept={int, NoneType}) = 56
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_slice_index_converter__doc__,
|
|
|
|
"test_slice_index_converter($module, a=12, b=34, c=56, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_SLICE_INDEX_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_slice_index_converter", _PyCFunction_CAST(test_slice_index_converter), METH_FASTCALL, test_slice_index_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_slice_index_converter_impl(PyObject *module, Py_ssize_t a, Py_ssize_t b,
|
|
|
|
Py_ssize_t c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_slice_index_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
Py_ssize_t a = 12;
|
|
|
|
Py_ssize_t b = 34;
|
|
|
|
Py_ssize_t c = 56;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_slice_index_converter", nargs, 0, 3)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyEval_SliceIndex(args[0], &a)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyEval_SliceIndexNotNone(args[1], &b)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 3) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyEval_SliceIndex(args[2], &c)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_slice_index_converter_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_slice_index_converter_impl(PyObject *module, Py_ssize_t a, Py_ssize_t b,
|
|
|
|
Py_ssize_t c)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=67506ed999361212 input=edeadb0ee126f531]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_size_t_converter
|
|
|
|
|
|
|
|
a: size_t = 12
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_size_t_converter__doc__,
|
|
|
|
"test_size_t_converter($module, a=12, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_SIZE_T_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_size_t_converter", _PyCFunction_CAST(test_size_t_converter), METH_FASTCALL, test_size_t_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_size_t_converter_impl(PyObject *module, size_t a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_size_t_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
size_t a = 12;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_size_t_converter", nargs, 0, 1)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
|
|
|
if (!_PyLong_Size_t_Converter(args[0], &a)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_size_t_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_size_t_converter_impl(PyObject *module, size_t a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=1653ecb5cbf775aa input=52e93a0fed0f1fb3]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_float_converter
|
|
|
|
|
|
|
|
a: float = 12.5
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_float_converter__doc__,
|
|
|
|
"test_float_converter($module, a=12.5, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_FLOAT_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_float_converter", _PyCFunction_CAST(test_float_converter), METH_FASTCALL, test_float_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_float_converter_impl(PyObject *module, float a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_float_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
float a = 12.5;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_float_converter", nargs, 0, 1)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
2019-08-24 23:10:39 -03:00
|
|
|
if (PyFloat_CheckExact(args[0])) {
|
|
|
|
a = (float) (PyFloat_AS_DOUBLE(args[0]));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
a = (float) PyFloat_AsDouble(args[0]);
|
|
|
|
if (a == -1.0 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
}
|
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_float_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_float_converter_impl(PyObject *module, float a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=36ad006990a8a91e input=259c0d98eca35034]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_double_converter
|
|
|
|
|
|
|
|
a: double = 12.5
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_double_converter__doc__,
|
|
|
|
"test_double_converter($module, a=12.5, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_DOUBLE_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_double_converter", _PyCFunction_CAST(test_double_converter), METH_FASTCALL, test_double_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_double_converter_impl(PyObject *module, double a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_double_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
double a = 12.5;
|
|
|
|
|
2019-01-11 10:01:14 -04:00
|
|
|
if (!_PyArg_CheckPositional("test_double_converter", nargs, 0, 1)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (nargs < 1) {
|
|
|
|
goto skip_optional;
|
|
|
|
}
|
2019-08-24 23:10:39 -03:00
|
|
|
if (PyFloat_CheckExact(args[0])) {
|
|
|
|
a = PyFloat_AS_DOUBLE(args[0]);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
a = PyFloat_AsDouble(args[0]);
|
|
|
|
if (a == -1.0 && PyErr_Occurred()) {
|
|
|
|
goto exit;
|
|
|
|
}
|
2018-12-25 04:17:28 -04:00
|
|
|
}
|
2019-01-11 10:01:14 -04:00
|
|
|
skip_optional:
|
2018-12-25 04:17:28 -04:00
|
|
|
return_value = test_double_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_double_converter_impl(PyObject *module, double a)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=7435925592bac795 input=c6a9945706a41c27]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_Py_complex_converter
|
|
|
|
|
|
|
|
a: Py_complex
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_Py_complex_converter__doc__,
|
|
|
|
"test_Py_complex_converter($module, a, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PY_COMPLEX_CONVERTER_METHODDEF \
|
|
|
|
{"test_Py_complex_converter", (PyCFunction)test_Py_complex_converter, METH_O, test_Py_complex_converter__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_complex_converter_impl(PyObject *module, Py_complex a);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_complex_converter(PyObject *module, PyObject *arg)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
Py_complex a;
|
|
|
|
|
2018-12-25 07:23:47 -04:00
|
|
|
a = PyComplex_AsCComplex(arg);
|
|
|
|
if (PyErr_Occurred()) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
return_value = test_Py_complex_converter_impl(module, a);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_complex_converter_impl(PyObject *module, Py_complex a)
|
2018-12-25 07:23:47 -04:00
|
|
|
/*[clinic end generated code: output=c2ecbec2144ca540 input=070f216a515beb79]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_str_converter
|
|
|
|
|
|
|
|
a: str = NULL
|
|
|
|
b: str = "ab"
|
|
|
|
c: str(accept={str}) = "cd"
|
|
|
|
d: str(accept={robuffer}) = "cef"
|
|
|
|
e: str(accept={str, NoneType}) = "gh"
|
|
|
|
f: str(accept={robuffer}, zeroes=True) = "ij"
|
|
|
|
g: str(accept={robuffer, str}, zeroes=True) = "kl"
|
|
|
|
h: str(accept={robuffer, str, NoneType}, zeroes=True) = "mn"
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_str_converter__doc__,
|
2019-09-14 06:24:05 -03:00
|
|
|
"test_str_converter($module, a=<unrepresentable>, b=\'ab\', c=\'cd\',\n"
|
|
|
|
" d=\'cef\', e=\'gh\', f=\'ij\', g=\'kl\', h=\'mn\', /)\n"
|
2018-12-25 04:17:28 -04:00
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_STR_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_str_converter", _PyCFunction_CAST(test_str_converter), METH_FASTCALL, test_str_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter_impl(PyObject *module, const char *a, const char *b,
|
|
|
|
const char *c, const char *d, const char *e,
|
2021-05-07 22:17:37 -03:00
|
|
|
const char *f, Py_ssize_t f_length, const char *g,
|
|
|
|
Py_ssize_t g_length, const char *h,
|
|
|
|
Py_ssize_t h_length);
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
const char *a = NULL;
|
|
|
|
const char *b = "ab";
|
|
|
|
const char *c = "cd";
|
|
|
|
const char *d = "cef";
|
|
|
|
const char *e = "gh";
|
|
|
|
const char *f = "ij";
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t f_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
const char *g = "kl";
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t g_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
const char *h = "mn";
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t h_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
if (!_PyArg_ParseStack(args, nargs, "|sssyzy#s#z#:test_str_converter",
|
|
|
|
&a, &b, &c, &d, &e, &f, &f_length, &g, &g_length, &h, &h_length)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
return_value = test_str_converter_impl(module, a, b, c, d, e, f, f_length, g, g_length, h, h_length);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter_impl(PyObject *module, const char *a, const char *b,
|
|
|
|
const char *c, const char *d, const char *e,
|
2021-05-07 22:17:37 -03:00
|
|
|
const char *f, Py_ssize_t f_length, const char *g,
|
|
|
|
Py_ssize_t g_length, const char *h,
|
|
|
|
Py_ssize_t h_length)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=82cb06d5237ef062 input=8afe9da8185cd38c]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_str_converter_encoding
|
|
|
|
|
|
|
|
a: str(encoding="idna")
|
|
|
|
b: str(encoding="idna", accept={str})
|
|
|
|
c: str(encoding="idna", accept={bytes, bytearray, str})
|
|
|
|
d: str(encoding="idna", zeroes=True)
|
|
|
|
e: str(encoding="idna", accept={bytes, bytearray, str}, zeroes=True)
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_str_converter_encoding__doc__,
|
|
|
|
"test_str_converter_encoding($module, a, b, c, d, e, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_STR_CONVERTER_ENCODING_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_str_converter_encoding", _PyCFunction_CAST(test_str_converter_encoding), METH_FASTCALL, test_str_converter_encoding__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter_encoding_impl(PyObject *module, char *a, char *b, char *c,
|
2021-05-07 22:17:37 -03:00
|
|
|
char *d, Py_ssize_t d_length, char *e,
|
|
|
|
Py_ssize_t e_length);
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter_encoding(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
char *a = NULL;
|
|
|
|
char *b = NULL;
|
|
|
|
char *c = NULL;
|
|
|
|
char *d = NULL;
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t d_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
char *e = NULL;
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t e_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
if (!_PyArg_ParseStack(args, nargs, "esesetes#et#:test_str_converter_encoding",
|
|
|
|
"idna", &a, "idna", &b, "idna", &c, "idna", &d, &d_length, "idna", &e, &e_length)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
return_value = test_str_converter_encoding_impl(module, a, b, c, d, d_length, e, e_length);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
/* Cleanup for a */
|
|
|
|
if (a) {
|
|
|
|
PyMem_FREE(a);
|
|
|
|
}
|
|
|
|
/* Cleanup for b */
|
|
|
|
if (b) {
|
|
|
|
PyMem_FREE(b);
|
|
|
|
}
|
|
|
|
/* Cleanup for c */
|
|
|
|
if (c) {
|
|
|
|
PyMem_FREE(c);
|
|
|
|
}
|
|
|
|
/* Cleanup for d */
|
|
|
|
if (d) {
|
|
|
|
PyMem_FREE(d);
|
|
|
|
}
|
|
|
|
/* Cleanup for e */
|
|
|
|
if (e) {
|
|
|
|
PyMem_FREE(e);
|
|
|
|
}
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_str_converter_encoding_impl(PyObject *module, char *a, char *b, char *c,
|
2021-05-07 22:17:37 -03:00
|
|
|
char *d, Py_ssize_t d_length, char *e,
|
|
|
|
Py_ssize_t e_length)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=8acb886a3843f3bc input=eb4c38e1f898f402]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_Py_UNICODE_converter
|
|
|
|
|
|
|
|
a: Py_UNICODE
|
|
|
|
b: Py_UNICODE(accept={str})
|
|
|
|
c: Py_UNICODE(accept={str, NoneType})
|
|
|
|
d: Py_UNICODE(zeroes=True)
|
|
|
|
e: Py_UNICODE(accept={str, NoneType}, zeroes=True)
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_Py_UNICODE_converter__doc__,
|
|
|
|
"test_Py_UNICODE_converter($module, a, b, c, d, e, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PY_UNICODE_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_Py_UNICODE_converter", _PyCFunction_CAST(test_Py_UNICODE_converter), METH_FASTCALL, test_Py_UNICODE_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_UNICODE_converter_impl(PyObject *module, const Py_UNICODE *a,
|
|
|
|
const Py_UNICODE *b, const Py_UNICODE *c,
|
2021-05-07 22:17:37 -03:00
|
|
|
const Py_UNICODE *d, Py_ssize_t d_length,
|
|
|
|
const Py_UNICODE *e, Py_ssize_t e_length);
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_UNICODE_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-10-03 04:42:54 -03:00
|
|
|
const Py_UNICODE *a = NULL;
|
|
|
|
const Py_UNICODE *b = NULL;
|
|
|
|
const Py_UNICODE *c = NULL;
|
|
|
|
const Py_UNICODE *d = NULL;
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t d_length;
|
2022-10-03 04:42:54 -03:00
|
|
|
const Py_UNICODE *e = NULL;
|
2021-05-07 22:17:37 -03:00
|
|
|
Py_ssize_t e_length;
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2020-06-30 03:03:15 -03:00
|
|
|
if (!_PyArg_ParseStack(args, nargs, "O&O&O&u#Z#:test_Py_UNICODE_converter",
|
|
|
|
_PyUnicode_WideCharString_Converter, &a, _PyUnicode_WideCharString_Converter, &b, _PyUnicode_WideCharString_Opt_Converter, &c, &d, &d_length, &e, &e_length)) {
|
2018-12-25 04:17:28 -04:00
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
return_value = test_Py_UNICODE_converter_impl(module, a, b, c, d, d_length, e, e_length);
|
|
|
|
|
|
|
|
exit:
|
2020-06-30 03:03:15 -03:00
|
|
|
/* Cleanup for a */
|
|
|
|
PyMem_Free((void *)a);
|
|
|
|
/* Cleanup for b */
|
|
|
|
PyMem_Free((void *)b);
|
|
|
|
/* Cleanup for c */
|
|
|
|
PyMem_Free((void *)c);
|
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_UNICODE_converter_impl(PyObject *module, const Py_UNICODE *a,
|
|
|
|
const Py_UNICODE *b, const Py_UNICODE *c,
|
2021-05-07 22:17:37 -03:00
|
|
|
const Py_UNICODE *d, Py_ssize_t d_length,
|
|
|
|
const Py_UNICODE *e, Py_ssize_t e_length)
|
2022-10-03 04:42:54 -03:00
|
|
|
/*[clinic end generated code: output=9f34a249b3071fdd input=064a3b68ad7f04b0]*/
|
2018-12-25 04:17:28 -04:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
|
2018-12-25 04:17:28 -04:00
|
|
|
/*[clinic input]
|
|
|
|
test_Py_buffer_converter
|
|
|
|
|
|
|
|
a: Py_buffer
|
|
|
|
b: Py_buffer(accept={buffer})
|
|
|
|
c: Py_buffer(accept={str, buffer})
|
|
|
|
d: Py_buffer(accept={str, buffer, NoneType})
|
|
|
|
e: Py_buffer(accept={rwbuffer})
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_Py_buffer_converter__doc__,
|
|
|
|
"test_Py_buffer_converter($module, a, b, c, d, e, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PY_BUFFER_CONVERTER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_Py_buffer_converter", _PyCFunction_CAST(test_Py_buffer_converter), METH_FASTCALL, test_Py_buffer_converter__doc__},
|
2018-12-25 04:17:28 -04:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_buffer_converter_impl(PyObject *module, Py_buffer *a, Py_buffer *b,
|
|
|
|
Py_buffer *c, Py_buffer *d, Py_buffer *e);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_buffer_converter(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
Py_buffer a = {NULL, NULL};
|
|
|
|
Py_buffer b = {NULL, NULL};
|
|
|
|
Py_buffer c = {NULL, NULL};
|
|
|
|
Py_buffer d = {NULL, NULL};
|
|
|
|
Py_buffer e = {NULL, NULL};
|
|
|
|
|
|
|
|
if (!_PyArg_ParseStack(args, nargs, "y*y*s*z*w*:test_Py_buffer_converter",
|
|
|
|
&a, &b, &c, &d, &e)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
return_value = test_Py_buffer_converter_impl(module, &a, &b, &c, &d, &e);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
/* Cleanup for a */
|
|
|
|
if (a.obj) {
|
|
|
|
PyBuffer_Release(&a);
|
|
|
|
}
|
|
|
|
/* Cleanup for b */
|
|
|
|
if (b.obj) {
|
|
|
|
PyBuffer_Release(&b);
|
|
|
|
}
|
|
|
|
/* Cleanup for c */
|
|
|
|
if (c.obj) {
|
|
|
|
PyBuffer_Release(&c);
|
|
|
|
}
|
|
|
|
/* Cleanup for d */
|
|
|
|
if (d.obj) {
|
|
|
|
PyBuffer_Release(&d);
|
|
|
|
}
|
|
|
|
/* Cleanup for e */
|
|
|
|
if (e.obj) {
|
|
|
|
PyBuffer_Release(&e);
|
|
|
|
}
|
|
|
|
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_Py_buffer_converter_impl(PyObject *module, Py_buffer *a, Py_buffer *b,
|
|
|
|
Py_buffer *c, Py_buffer *d, Py_buffer *e)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=a153b71b4f45f952 input=6a9da0f56f9525fd]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keywords
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keywords__doc__,
|
|
|
|
"test_keywords($module, /, a, b)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORDS_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keywords", _PyCFunction_CAST(test_keywords), METH_FASTCALL|METH_KEYWORDS, test_keywords__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_impl(PyObject *module, PyObject *a, PyObject *b);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keywords",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[2];
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
return_value = test_keywords_impl(module, a, b);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_impl(PyObject *module, PyObject *a, PyObject *b)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=73d46a9ae3320f96 input=0d3484844749c05b]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keywords_kwonly
|
|
|
|
|
|
|
|
a: object
|
|
|
|
*
|
|
|
|
b: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keywords_kwonly__doc__,
|
|
|
|
"test_keywords_kwonly($module, /, a, *, b)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORDS_KWONLY_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keywords_kwonly", _PyCFunction_CAST(test_keywords_kwonly), METH_FASTCALL|METH_KEYWORDS, test_keywords_kwonly__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly_impl(PyObject *module, PyObject *a, PyObject *b);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keywords_kwonly",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[2];
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
return_value = test_keywords_kwonly_impl(module, a, b);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly_impl(PyObject *module, PyObject *a, PyObject *b)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=c9f02a41f425897d input=384adc78bfa0bff7]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keywords_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = None
|
|
|
|
c: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keywords_opt__doc__,
|
|
|
|
"test_keywords_opt($module, /, a, b=None, c=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORDS_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keywords_opt", _PyCFunction_CAST(test_keywords_opt), METH_FASTCALL|METH_KEYWORDS, test_keywords_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 3
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keywords_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 3, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
skip_optional_pos:
|
|
|
|
return_value = test_keywords_opt_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=b35d4e66f7283e46 input=eda7964f784f4607]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keywords_opt_kwonly
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = None
|
|
|
|
*
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keywords_opt_kwonly__doc__,
|
|
|
|
"test_keywords_opt_kwonly($module, /, a, b=None, *, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORDS_OPT_KWONLY_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keywords_opt_kwonly", _PyCFunction_CAST(test_keywords_opt_kwonly), METH_FASTCALL|METH_KEYWORDS, test_keywords_opt_kwonly__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt_kwonly_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt_kwonly(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 4
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keywords_opt_kwonly",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 2, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional_pos:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_keywords_opt_kwonly_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_opt_kwonly_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=ede7e6e65106bf2b input=209387a4815e5082]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keywords_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
*
|
|
|
|
b: object = None
|
|
|
|
c: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keywords_kwonly_opt__doc__,
|
|
|
|
"test_keywords_kwonly_opt($module, /, a, *, b=None, c=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORDS_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keywords_kwonly_opt", _PyCFunction_CAST(test_keywords_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_keywords_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 3
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keywords_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_keywords_kwonly_opt_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keywords_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=36d4df939a4c3eef input=18393cc64fa000f4]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords__doc__,
|
|
|
|
"test_posonly_keywords($module, a, /, b)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords", _PyCFunction_CAST(test_posonly_keywords), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_impl(PyObject *module, PyObject *a, PyObject *b);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 1
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[2];
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
return_value = test_posonly_keywords_impl(module, a, b);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_impl(PyObject *module, PyObject *a, PyObject *b)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=4835f4b6cf386c28 input=1767b0ebdf06060e]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_kwonly
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
*
|
|
|
|
c: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_kwonly__doc__,
|
|
|
|
"test_posonly_kwonly($module, a, /, *, c)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KWONLY_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_kwonly", _PyCFunction_CAST(test_posonly_kwonly), METH_FASTCALL|METH_KEYWORDS, test_posonly_kwonly__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_impl(PyObject *module, PyObject *a, PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 1
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_kwonly",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[2];
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *c;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
c = args[1];
|
|
|
|
return_value = test_posonly_kwonly_impl(module, a, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_impl(PyObject *module, PyObject *a, PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=2570ea156a8d3cb5 input=9042f2818f664839]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_kwonly
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
*
|
|
|
|
c: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_kwonly__doc__,
|
|
|
|
"test_posonly_keywords_kwonly($module, a, /, b, *, c)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_KWONLY_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_kwonly", _PyCFunction_CAST(test_posonly_keywords_kwonly), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_kwonly__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_kwonly",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
c = args[2];
|
|
|
|
return_value = test_posonly_keywords_kwonly_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=aaa0e6b5ce02900d input=29546ebdca492fea]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_opt__doc__,
|
|
|
|
"test_posonly_keywords_opt($module, a, /, b, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_opt", _PyCFunction_CAST(test_posonly_keywords_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 3
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 2;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 4, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_pos:
|
|
|
|
return_value = test_posonly_keywords_opt_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=1d9f2d8420d0a85f input=cdf5a9625e554e9b]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_opt2
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object = None
|
|
|
|
c: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_opt2__doc__,
|
|
|
|
"test_posonly_keywords_opt2($module, a, /, b=None, c=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_OPT2_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_opt2", _PyCFunction_CAST(test_posonly_keywords_opt2), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_opt2__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_opt2",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 3, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
skip_optional_pos:
|
|
|
|
return_value = test_posonly_keywords_opt2_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=a83caa0505b296cf input=1581299d21d16f14]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_opt_keywords_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = None
|
|
|
|
/
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_opt_keywords_opt__doc__,
|
|
|
|
"test_posonly_opt_keywords_opt($module, a, b=None, /, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_OPT_KEYWORDS_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_opt_keywords_opt", _PyCFunction_CAST(test_posonly_opt_keywords_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_opt_keywords_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_opt_keywords_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 4, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional_posonly;
|
|
|
|
}
|
|
|
|
noptargs--;
|
|
|
|
b = args[1];
|
|
|
|
skip_optional_posonly:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_pos:
|
|
|
|
return_value = test_posonly_opt_keywords_opt_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=0b24fba3dc04d26b input=408798ec3d42949f]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
*
|
|
|
|
b: object
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_kwonly_opt__doc__,
|
|
|
|
"test_posonly_kwonly_opt($module, a, /, *, b, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_kwonly_opt", _PyCFunction_CAST(test_posonly_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 3
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 2;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_kwonly_opt_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=592b217bca2f7bcc input=8d8e5643bbbc2309]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_kwonly_opt2
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
*
|
|
|
|
b: object = None
|
|
|
|
c: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_kwonly_opt2__doc__,
|
|
|
|
"test_posonly_kwonly_opt2($module, a, /, *, b=None, c=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KWONLY_OPT2_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_kwonly_opt2", _PyCFunction_CAST(test_posonly_kwonly_opt2), METH_FASTCALL|METH_KEYWORDS, test_posonly_kwonly_opt2__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt2_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt2(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_kwonly_opt2",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_kwonly_opt2_impl(module, a, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_kwonly_opt2_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=b8b00420826bc11f input=f7e5eed94f75fff0]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_opt_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = None
|
|
|
|
/
|
|
|
|
*
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_opt_kwonly_opt__doc__,
|
|
|
|
"test_posonly_opt_kwonly_opt($module, a, b=None, /, *, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_OPT_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_opt_kwonly_opt", _PyCFunction_CAST(test_posonly_opt_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_opt_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_opt_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 2, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional_posonly;
|
|
|
|
}
|
|
|
|
noptargs--;
|
|
|
|
b = args[1];
|
|
|
|
skip_optional_posonly:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_opt_kwonly_opt_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_kwonly_opt_impl(PyObject *module, PyObject *a, PyObject *b,
|
|
|
|
PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=3b9ee879ebee285a input=1e557dc979d120fd]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
*
|
|
|
|
c: object
|
|
|
|
d: object = None
|
|
|
|
e: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_kwonly_opt__doc__,
|
|
|
|
"test_posonly_keywords_kwonly_opt($module, a, /, b, *, c, d=None, e=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_kwonly_opt", _PyCFunction_CAST(test_posonly_keywords_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d,
|
|
|
|
PyObject *e);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 4
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), &_Py_ID(e), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", "e", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[5];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 3;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
PyObject *e = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
c = args[2];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[3]) {
|
|
|
|
d = args[3];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
e = args[4];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_keywords_kwonly_opt_impl(module, a, b, c, d, e);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d,
|
|
|
|
PyObject *e)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=d380f84f81cc0e45 input=c3884a4f956fdc89]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_kwonly_opt2
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
*
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_kwonly_opt2__doc__,
|
|
|
|
"test_posonly_keywords_kwonly_opt2($module, a, /, b, *, c=None, d=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_KWONLY_OPT2_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_kwonly_opt2", _PyCFunction_CAST(test_posonly_keywords_kwonly_opt2), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_kwonly_opt2__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt2_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt2(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 3
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_kwonly_opt2",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[4];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 2;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
d = args[3];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_keywords_kwonly_opt2_impl(module, a, b, c, d);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_kwonly_opt2_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c, PyObject *d)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=ee629e962cb06992 input=68d01d7c0f6dafb0]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_opt_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object
|
|
|
|
c: object = None
|
|
|
|
*
|
|
|
|
d: object = None
|
|
|
|
e: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_opt_kwonly_opt__doc__,
|
|
|
|
"test_posonly_keywords_opt_kwonly_opt($module, a, /, b, c=None, *,\n"
|
|
|
|
" d=None, e=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_OPT_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_opt_kwonly_opt", _PyCFunction_CAST(test_posonly_keywords_opt_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_opt_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 4
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), &_Py_ID(e), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", "e", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_opt_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[5];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 2;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
PyObject *e = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 3, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
b = args[1];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional_pos:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[3]) {
|
|
|
|
d = args[3];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
e = args[4];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_keywords_opt_kwonly_opt_impl(module, a, b, c, d, e);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=a2721babb42ecfd1 input=d0883d45876f186c]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_keywords_opt2_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
/
|
|
|
|
b: object = None
|
|
|
|
c: object = None
|
|
|
|
*
|
|
|
|
d: object = None
|
|
|
|
e: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_keywords_opt2_kwonly_opt__doc__,
|
|
|
|
"test_posonly_keywords_opt2_kwonly_opt($module, a, /, b=None, c=None, *,\n"
|
|
|
|
" d=None, e=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_KEYWORDS_OPT2_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_keywords_opt2_kwonly_opt", _PyCFunction_CAST(test_posonly_keywords_opt2_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_keywords_opt2_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 4
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), &_Py_ID(d), &_Py_ID(e), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "b", "c", "d", "e", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_keywords_opt2_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[5];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
PyObject *e = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 3, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = args[1];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional_pos:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[3]) {
|
|
|
|
d = args[3];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
e = args[4];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_keywords_opt2_kwonly_opt_impl(module, a, b, c, d, e);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_keywords_opt2_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=0626203eedb6e7e8 input=c95e2e1ec93035ad]*/
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_posonly_opt_keywords_opt_kwonly_opt
|
|
|
|
|
|
|
|
a: object
|
|
|
|
b: object = None
|
|
|
|
/
|
|
|
|
c: object = None
|
|
|
|
d: object = None
|
|
|
|
*
|
|
|
|
e: object = None
|
|
|
|
f: object = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_posonly_opt_keywords_opt_kwonly_opt__doc__,
|
|
|
|
"test_posonly_opt_keywords_opt_kwonly_opt($module, a, b=None, /, c=None,\n"
|
|
|
|
" d=None, *, e=None, f=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_POSONLY_OPT_KEYWORDS_OPT_KWONLY_OPT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_posonly_opt_keywords_opt_kwonly_opt", _PyCFunction_CAST(test_posonly_opt_keywords_opt_kwonly_opt), METH_FASTCALL|METH_KEYWORDS, test_posonly_opt_keywords_opt_kwonly_opt__doc__},
|
2019-03-14 05:32:22 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e,
|
|
|
|
PyObject *f);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt_kwonly_opt(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 4
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(c), &_Py_ID(d), &_Py_ID(e), &_Py_ID(f), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-03-14 05:32:22 -03:00
|
|
|
static const char * const _keywords[] = {"", "", "c", "d", "e", "f", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_posonly_opt_keywords_opt_kwonly_opt",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-03-14 05:32:22 -03:00
|
|
|
PyObject *argsbuf[6];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *b = Py_None;
|
|
|
|
PyObject *c = Py_None;
|
|
|
|
PyObject *d = Py_None;
|
|
|
|
PyObject *e = Py_None;
|
|
|
|
PyObject *f = Py_None;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 4, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
if (nargs < 2) {
|
|
|
|
goto skip_optional_posonly;
|
|
|
|
}
|
|
|
|
noptargs--;
|
|
|
|
b = args[1];
|
|
|
|
skip_optional_posonly:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
if (args[2]) {
|
|
|
|
c = args[2];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (args[3]) {
|
|
|
|
d = args[3];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_pos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
skip_optional_pos:
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[4]) {
|
|
|
|
e = args[4];
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
f = args[5];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_posonly_opt_keywords_opt_kwonly_opt_impl(module, a, b, c, d, e, f);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_posonly_opt_keywords_opt_kwonly_opt_impl(PyObject *module, PyObject *a,
|
|
|
|
PyObject *b, PyObject *c,
|
|
|
|
PyObject *d, PyObject *e,
|
|
|
|
PyObject *f)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=07d8acc04558a5a0 input=9914857713c5bbf8]*/
|
2019-08-29 11:49:08 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_keyword_only_parameter
|
|
|
|
|
|
|
|
|
|
|
|
*
|
|
|
|
co_lnotab: PyBytesObject(c_default="(PyBytesObject *)self->co_lnotab") = None
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_keyword_only_parameter__doc__,
|
|
|
|
"test_keyword_only_parameter($module, /, *, co_lnotab=None)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_KEYWORD_ONLY_PARAMETER_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_keyword_only_parameter", _PyCFunction_CAST(test_keyword_only_parameter), METH_FASTCALL|METH_KEYWORDS, test_keyword_only_parameter__doc__},
|
2019-08-29 11:49:08 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keyword_only_parameter_impl(PyObject *module, PyBytesObject *co_lnotab);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keyword_only_parameter(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 1
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(co_lnotab), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2019-08-29 11:49:08 -03:00
|
|
|
static const char * const _keywords[] = {"co_lnotab", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_keyword_only_parameter",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2019-08-29 11:49:08 -03:00
|
|
|
PyObject *argsbuf[1];
|
|
|
|
Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
|
|
|
|
PyBytesObject *co_lnotab = (PyBytesObject *)self->co_lnotab;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 0, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (!PyBytes_Check(args[0])) {
|
|
|
|
_PyArg_BadArgument("test_keyword_only_parameter", "argument 'co_lnotab'", "bytes", args[0]);
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
co_lnotab = (PyBytesObject *)args[0];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_keyword_only_parameter_impl(module, co_lnotab);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_keyword_only_parameter_impl(PyObject *module, PyBytesObject *co_lnotab)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=b12fe2e515a62603 input=303df5046c7e37a3]*/
|
2020-04-18 11:52:48 -03:00
|
|
|
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
output push
|
|
|
|
output preset buffer
|
|
|
|
[clinic start generated code]*/
|
|
|
|
/*[clinic end generated code: output=da39a3ee5e6b4b0d input=5bff3376ee0df0b5]*/
|
|
|
|
|
|
|
|
#ifdef CONDITION_A
|
|
|
|
/*[clinic input]
|
|
|
|
test_preprocessor_guarded_condition_a
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_condition_a_impl(PyObject *module)
|
|
|
|
/*[clinic end generated code: output=ad012af18085add6 input=8edb8706a98cda7e]*/
|
|
|
|
#elif CONDITION_B
|
|
|
|
/*[clinic input]
|
|
|
|
test_preprocessor_guarded_elif_condition_b
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_elif_condition_b_impl(PyObject *module)
|
|
|
|
/*[clinic end generated code: output=615f2dee82b138d1 input=53777cebbf7fee32]*/
|
|
|
|
#else
|
|
|
|
/*[clinic input]
|
|
|
|
test_preprocessor_guarded_else
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_else_impl(PyObject *module)
|
|
|
|
/*[clinic end generated code: output=13af7670aac51b12 input=6657ab31d74c29fc]*/
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
dump buffer
|
|
|
|
output pop
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
#if defined(CONDITION_A)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_preprocessor_guarded_condition_a__doc__,
|
|
|
|
"test_preprocessor_guarded_condition_a($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_CONDITION_A_METHODDEF \
|
|
|
|
{"test_preprocessor_guarded_condition_a", (PyCFunction)test_preprocessor_guarded_condition_a, METH_NOARGS, test_preprocessor_guarded_condition_a__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_condition_a(PyObject *module, PyObject *Py_UNUSED(ignored))
|
|
|
|
{
|
|
|
|
return test_preprocessor_guarded_condition_a_impl(module);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* defined(CONDITION_A) */
|
|
|
|
|
|
|
|
#if !defined(CONDITION_A) && (CONDITION_B)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_preprocessor_guarded_elif_condition_b__doc__,
|
|
|
|
"test_preprocessor_guarded_elif_condition_b($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_ELIF_CONDITION_B_METHODDEF \
|
|
|
|
{"test_preprocessor_guarded_elif_condition_b", (PyCFunction)test_preprocessor_guarded_elif_condition_b, METH_NOARGS, test_preprocessor_guarded_elif_condition_b__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_elif_condition_b(PyObject *module, PyObject *Py_UNUSED(ignored))
|
|
|
|
{
|
|
|
|
return test_preprocessor_guarded_elif_condition_b_impl(module);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !defined(CONDITION_A) && (CONDITION_B) */
|
|
|
|
|
|
|
|
#if !defined(CONDITION_A) && !(CONDITION_B)
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_preprocessor_guarded_else__doc__,
|
|
|
|
"test_preprocessor_guarded_else($module, /)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_ELSE_METHODDEF \
|
|
|
|
{"test_preprocessor_guarded_else", (PyCFunction)test_preprocessor_guarded_else, METH_NOARGS, test_preprocessor_guarded_else__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_preprocessor_guarded_else(PyObject *module, PyObject *Py_UNUSED(ignored))
|
|
|
|
{
|
|
|
|
return test_preprocessor_guarded_else_impl(module);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !defined(CONDITION_A) && !(CONDITION_B) */
|
|
|
|
|
|
|
|
#ifndef TEST_PREPROCESSOR_GUARDED_CONDITION_A_METHODDEF
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_CONDITION_A_METHODDEF
|
|
|
|
#endif /* !defined(TEST_PREPROCESSOR_GUARDED_CONDITION_A_METHODDEF) */
|
|
|
|
|
|
|
|
#ifndef TEST_PREPROCESSOR_GUARDED_ELIF_CONDITION_B_METHODDEF
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_ELIF_CONDITION_B_METHODDEF
|
|
|
|
#endif /* !defined(TEST_PREPROCESSOR_GUARDED_ELIF_CONDITION_B_METHODDEF) */
|
|
|
|
|
|
|
|
#ifndef TEST_PREPROCESSOR_GUARDED_ELSE_METHODDEF
|
|
|
|
#define TEST_PREPROCESSOR_GUARDED_ELSE_METHODDEF
|
|
|
|
#endif /* !defined(TEST_PREPROCESSOR_GUARDED_ELSE_METHODDEF) */
|
|
|
|
/*[clinic end generated code: output=3804bb18d454038c input=3fc80c9989d2f2e1]*/
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_vararg_and_posonly
|
|
|
|
|
|
|
|
|
|
|
|
a: object
|
|
|
|
*args: object
|
|
|
|
/
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_vararg_and_posonly__doc__,
|
|
|
|
"test_vararg_and_posonly($module, a, /, *args)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_VARARG_AND_POSONLY_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_vararg_and_posonly", _PyCFunction_CAST(test_vararg_and_posonly), METH_FASTCALL, test_vararg_and_posonly__doc__},
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_and_posonly_impl(PyObject *module, PyObject *a, PyObject *args);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_and_posonly(PyObject *module, PyObject *const *args, Py_ssize_t nargs)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *__clinic_args = NULL;
|
|
|
|
|
|
|
|
if (!_PyArg_CheckPositional("test_vararg_and_posonly", nargs, 1, PY_SSIZE_T_MAX)) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
__clinic_args = PyTuple_New(nargs - 1);
|
|
|
|
for (Py_ssize_t i = 0; i < nargs - 1; ++i) {
|
|
|
|
PyTuple_SET_ITEM(__clinic_args, i, args[1 + i]);
|
|
|
|
}
|
|
|
|
return_value = test_vararg_and_posonly_impl(module, a, __clinic_args);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
Py_XDECREF(__clinic_args);
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_and_posonly_impl(PyObject *module, PyObject *a, PyObject *args)
|
2022-05-03 15:25:41 -03:00
|
|
|
/*[clinic end generated code: output=548bca3a127c22c1 input=08dc2bf7afbf1613]*/
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_vararg
|
|
|
|
|
|
|
|
|
|
|
|
a: object
|
|
|
|
*args: object
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_vararg__doc__,
|
|
|
|
"test_vararg($module, /, a, *args)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_VARARG_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_vararg", _PyCFunction_CAST(test_vararg), METH_FASTCALL|METH_KEYWORDS, test_vararg__doc__},
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_impl(PyObject *module, PyObject *a, PyObject *args);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 1
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2021-07-16 12:43:02 -03:00
|
|
|
static const char * const _keywords[] = {"a", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_vararg",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2021-07-16 12:43:02 -03:00
|
|
|
PyObject *argsbuf[2];
|
|
|
|
Py_ssize_t noptargs = 0 + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *__clinic_args = NULL;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywordsWithVararg(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
__clinic_args = args[1];
|
|
|
|
return_value = test_vararg_impl(module, a, __clinic_args);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
Py_XDECREF(__clinic_args);
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_impl(PyObject *module, PyObject *a, PyObject *args)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=6661f3ca97d85e8c input=81d33815ad1bae6e]*/
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_vararg_with_default
|
|
|
|
|
|
|
|
|
|
|
|
a: object
|
|
|
|
*args: object
|
|
|
|
b: bool = False
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_vararg_with_default__doc__,
|
|
|
|
"test_vararg_with_default($module, /, a, *args, b=False)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_VARARG_WITH_DEFAULT_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_vararg_with_default", _PyCFunction_CAST(test_vararg_with_default), METH_FASTCALL|METH_KEYWORDS, test_vararg_with_default__doc__},
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_default_impl(PyObject *module, PyObject *a, PyObject *args,
|
|
|
|
int b);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_default(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(a), &_Py_ID(b), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2021-07-16 12:43:02 -03:00
|
|
|
static const char * const _keywords[] = {"a", "b", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_vararg_with_default",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2021-07-16 12:43:02 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = 0 + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1;
|
|
|
|
PyObject *a;
|
|
|
|
PyObject *__clinic_args = NULL;
|
|
|
|
int b = 0;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywordsWithVararg(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, 1, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
a = args[0];
|
|
|
|
__clinic_args = args[1];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
b = PyObject_IsTrue(args[2]);
|
|
|
|
if (b < 0) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_vararg_with_default_impl(module, a, __clinic_args, b);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
Py_XDECREF(__clinic_args);
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_default_impl(PyObject *module, PyObject *a, PyObject *args,
|
|
|
|
int b)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=5fe3cfccb1bef781 input=6e110b54acd9b22d]*/
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_vararg_with_only_defaults
|
|
|
|
|
|
|
|
|
|
|
|
*args: object
|
|
|
|
b: bool = False
|
|
|
|
c: object = ' '
|
|
|
|
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_vararg_with_only_defaults__doc__,
|
|
|
|
"test_vararg_with_only_defaults($module, /, *args, b=False, c=\' \')\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_VARARG_WITH_ONLY_DEFAULTS_METHODDEF \
|
2022-05-03 15:25:41 -03:00
|
|
|
{"test_vararg_with_only_defaults", _PyCFunction_CAST(test_vararg_with_only_defaults), METH_FASTCALL|METH_KEYWORDS, test_vararg_with_only_defaults__doc__},
|
2021-07-16 12:43:02 -03:00
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_only_defaults_impl(PyObject *module, PyObject *args, int b,
|
|
|
|
PyObject *c);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_only_defaults(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 2
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(b), &_Py_ID(c), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2021-07-16 12:43:02 -03:00
|
|
|
static const char * const _keywords[] = {"b", "c", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_vararg_with_only_defaults",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2021-07-16 12:43:02 -03:00
|
|
|
PyObject *argsbuf[3];
|
|
|
|
Py_ssize_t noptargs = 0 + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
|
|
|
|
PyObject *__clinic_args = NULL;
|
|
|
|
int b = 0;
|
|
|
|
PyObject *c = " ";
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywordsWithVararg(args, nargs, NULL, kwnames, &_parser, 0, 0, 0, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
__clinic_args = args[0];
|
|
|
|
if (!noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
if (args[1]) {
|
|
|
|
b = PyObject_IsTrue(args[1]);
|
|
|
|
if (b < 0) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (!--noptargs) {
|
|
|
|
goto skip_optional_kwonly;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
c = args[2];
|
|
|
|
skip_optional_kwonly:
|
|
|
|
return_value = test_vararg_with_only_defaults_impl(module, __clinic_args, b, c);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
Py_XDECREF(__clinic_args);
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_vararg_with_only_defaults_impl(PyObject *module, PyObject *args, int b,
|
|
|
|
PyObject *c)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=dd21b28f0db26a4b input=fa56a709a035666e]*/
|
2022-07-07 06:29:34 -03:00
|
|
|
|
|
|
|
/*[clinic input]
|
|
|
|
test_paramname_module
|
|
|
|
|
|
|
|
module as mod: object
|
|
|
|
[clinic start generated code]*/
|
|
|
|
|
|
|
|
PyDoc_STRVAR(test_paramname_module__doc__,
|
|
|
|
"test_paramname_module($module, /, module)\n"
|
|
|
|
"--\n"
|
|
|
|
"\n");
|
|
|
|
|
|
|
|
#define TEST_PARAMNAME_MODULE_METHODDEF \
|
|
|
|
{"test_paramname_module", _PyCFunction_CAST(test_paramname_module), METH_FASTCALL|METH_KEYWORDS, test_paramname_module__doc__},
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_paramname_module_impl(PyObject *module, PyObject *mod);
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_paramname_module(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
|
|
|
|
{
|
|
|
|
PyObject *return_value = NULL;
|
2022-08-13 07:09:40 -03:00
|
|
|
#if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE)
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-08-13 07:09:40 -03:00
|
|
|
#define NUM_KEYWORDS 1
|
2022-08-11 18:25:49 -03:00
|
|
|
static struct {
|
|
|
|
PyGC_Head _this_is_not_used;
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
PyObject *ob_item[NUM_KEYWORDS];
|
|
|
|
} _kwtuple = {
|
|
|
|
.ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS)
|
|
|
|
.ob_item = { &_Py_ID(module), },
|
|
|
|
};
|
|
|
|
#undef NUM_KEYWORDS
|
2022-08-13 07:09:40 -03:00
|
|
|
#define KWTUPLE (&_kwtuple.ob_base.ob_base)
|
|
|
|
|
|
|
|
#else // !Py_BUILD_CORE
|
|
|
|
# define KWTUPLE NULL
|
|
|
|
#endif // !Py_BUILD_CORE
|
2022-08-11 18:25:49 -03:00
|
|
|
|
2022-07-07 06:29:34 -03:00
|
|
|
static const char * const _keywords[] = {"module", NULL};
|
2022-08-11 18:25:49 -03:00
|
|
|
static _PyArg_Parser _parser = {
|
|
|
|
.keywords = _keywords,
|
|
|
|
.fname = "test_paramname_module",
|
|
|
|
.kwtuple = KWTUPLE,
|
|
|
|
};
|
|
|
|
#undef KWTUPLE
|
2022-07-07 06:29:34 -03:00
|
|
|
PyObject *argsbuf[1];
|
|
|
|
PyObject *mod;
|
|
|
|
|
|
|
|
args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf);
|
|
|
|
if (!args) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
mod = args[0];
|
|
|
|
return_value = test_paramname_module_impl(module, mod);
|
|
|
|
|
|
|
|
exit:
|
|
|
|
return return_value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject *
|
|
|
|
test_paramname_module_impl(PyObject *module, PyObject *mod)
|
2022-08-13 07:09:40 -03:00
|
|
|
/*[clinic end generated code: output=4a2a849ecbcc8b53 input=afefe259667f13ba]*/
|