1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
|
#include "parts.h"
#include "util.h"
static PyObject *
tuple_check(PyObject* Py_UNUSED(module), PyObject *obj)
{
NULLABLE(obj);
return PyLong_FromLong(PyTuple_Check(obj));
}
static PyObject *
tuple_checkexact(PyObject* Py_UNUSED(module), PyObject *obj)
{
NULLABLE(obj);
return PyLong_FromLong(PyTuple_CheckExact(obj));
}
static PyObject *
tuple_new(PyObject* Py_UNUSED(module), PyObject *len)
{
return PyTuple_New(PyLong_AsSsize_t(len));
}
static PyObject *
tuple_pack(PyObject *Py_UNUSED(module), PyObject *args)
{
PyObject *arg1 = NULL, *arg2 = NULL;
Py_ssize_t size;
if (!PyArg_ParseTuple(args, "n|OO", &size, &arg1, &arg2)) {
return NULL;
}
if (arg1) {
NULLABLE(arg1);
if (arg2) {
NULLABLE(arg2);
return PyTuple_Pack(size, arg1, arg2);
}
return PyTuple_Pack(size, arg1);
}
return PyTuple_Pack(size);
}
static PyObject *
tuple_size(PyObject *Py_UNUSED(module), PyObject *obj)
{
NULLABLE(obj);
RETURN_SIZE(PyTuple_Size(obj));
}
static PyObject *
tuple_getitem(PyObject *Py_UNUSED(module), PyObject *args)
{
PyObject *obj;
Py_ssize_t i;
if (!PyArg_ParseTuple(args, "On", &obj, &i)) {
return NULL;
}
NULLABLE(obj);
return Py_XNewRef(PyTuple_GetItem(obj, i));
}
static PyObject *
tuple_getslice(PyObject *Py_UNUSED(module), PyObject *args)
{
PyObject *obj;
Py_ssize_t ilow, ihigh;
if (!PyArg_ParseTuple(args, "Onn", &obj, &ilow, &ihigh)) {
return NULL;
}
NULLABLE(obj);
return PyTuple_GetSlice(obj, ilow, ihigh);
}
static PyObject *
tuple_setitem(PyObject *Py_UNUSED(module), PyObject *args)
{
PyObject *obj, *value, *newtuple = NULL;
Py_ssize_t i;
if (!PyArg_ParseTuple(args, "OnO", &obj, &i, &value)) {
return NULL;
}
NULLABLE(value);
if (PyTuple_CheckExact(obj)) {
Py_ssize_t size = PyTuple_Size(obj);
newtuple = PyTuple_New(size);
if (!newtuple) {
return NULL;
}
for (Py_ssize_t n = 0; n < size; n++) {
if (PyTuple_SetItem(newtuple, n,
Py_XNewRef(PyTuple_GetItem(obj, n))) == -1) {
Py_DECREF(newtuple);
return NULL;
}
}
if (PyTuple_SetItem(newtuple, i, Py_XNewRef(value)) == -1) {
Py_DECREF(newtuple);
return NULL;
}
return newtuple;
}
else {
NULLABLE(obj);
if (PyTuple_SetItem(obj, i, Py_XNewRef(value)) == -1) {
return NULL;
}
return Py_XNewRef(obj);
}
}
static PyMethodDef test_methods[] = {
{"tuple_check", tuple_check, METH_O},
{"tuple_checkexact", tuple_checkexact, METH_O},
{"tuple_new", tuple_new, METH_O},
{"tuple_pack", tuple_pack, METH_VARARGS},
{"tuple_size", tuple_size, METH_O},
{"tuple_getitem", tuple_getitem, METH_VARARGS},
{"tuple_getslice", tuple_getslice, METH_VARARGS},
{"tuple_setitem", tuple_setitem, METH_VARARGS},
{NULL},
};
int
_PyTestLimitedCAPI_Init_Tuple(PyObject *m)
{
if (PyModule_AddFunctions(m, test_methods) < 0) {
return -1;
}
return 0;
}
|