bpo-40956: Convert _sqlite3.Row to Argument Clinic (GH-23964)
This commit is contained in:
parent
0159e5efee
commit
84d79cfda9
|
@ -0,0 +1,56 @@
|
||||||
|
/*[clinic input]
|
||||||
|
preserve
|
||||||
|
[clinic start generated code]*/
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
pysqlite_row_new_impl(PyTypeObject *type, pysqlite_Cursor *cursor,
|
||||||
|
PyObject *data);
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
pysqlite_row_new(PyTypeObject *type, PyObject *args, PyObject *kwargs)
|
||||||
|
{
|
||||||
|
PyObject *return_value = NULL;
|
||||||
|
pysqlite_Cursor *cursor;
|
||||||
|
PyObject *data;
|
||||||
|
|
||||||
|
if ((type == pysqlite_RowType) &&
|
||||||
|
!_PyArg_NoKeywords("Row", kwargs)) {
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
if (!_PyArg_CheckPositional("Row", PyTuple_GET_SIZE(args), 2, 2)) {
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
if (!PyObject_TypeCheck(PyTuple_GET_ITEM(args, 0), pysqlite_CursorType)) {
|
||||||
|
_PyArg_BadArgument("Row", "argument 1", (pysqlite_CursorType)->tp_name, PyTuple_GET_ITEM(args, 0));
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
cursor = (pysqlite_Cursor *)PyTuple_GET_ITEM(args, 0);
|
||||||
|
if (!PyTuple_Check(PyTuple_GET_ITEM(args, 1))) {
|
||||||
|
_PyArg_BadArgument("Row", "argument 2", "tuple", PyTuple_GET_ITEM(args, 1));
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
data = PyTuple_GET_ITEM(args, 1);
|
||||||
|
return_value = pysqlite_row_new_impl(type, cursor, data);
|
||||||
|
|
||||||
|
exit:
|
||||||
|
return return_value;
|
||||||
|
}
|
||||||
|
|
||||||
|
PyDoc_STRVAR(pysqlite_row_keys__doc__,
|
||||||
|
"keys($self, /)\n"
|
||||||
|
"--\n"
|
||||||
|
"\n"
|
||||||
|
"Returns the keys of the row.");
|
||||||
|
|
||||||
|
#define PYSQLITE_ROW_KEYS_METHODDEF \
|
||||||
|
{"keys", (PyCFunction)pysqlite_row_keys, METH_NOARGS, pysqlite_row_keys__doc__},
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
pysqlite_row_keys_impl(pysqlite_Row *self);
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
pysqlite_row_keys(pysqlite_Row *self, PyObject *Py_UNUSED(ignored))
|
||||||
|
{
|
||||||
|
return pysqlite_row_keys_impl(self);
|
||||||
|
}
|
||||||
|
/*[clinic end generated code: output=8d29220b9cde035d input=a9049054013a1b77]*/
|
|
@ -23,6 +23,13 @@
|
||||||
|
|
||||||
#include "row.h"
|
#include "row.h"
|
||||||
#include "cursor.h"
|
#include "cursor.h"
|
||||||
|
#include "clinic/row.c.h"
|
||||||
|
|
||||||
|
/*[clinic input]
|
||||||
|
module _sqlite3
|
||||||
|
class _sqlite3.Row "pysqlite_Row *" "pysqlite_RowType"
|
||||||
|
[clinic start generated code]*/
|
||||||
|
/*[clinic end generated code: output=da39a3ee5e6b4b0d input=384227da65f250fd]*/
|
||||||
|
|
||||||
void pysqlite_row_dealloc(pysqlite_Row* self)
|
void pysqlite_row_dealloc(pysqlite_Row* self)
|
||||||
{
|
{
|
||||||
|
@ -35,30 +42,25 @@ void pysqlite_row_dealloc(pysqlite_Row* self)
|
||||||
Py_DECREF(tp);
|
Py_DECREF(tp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*[clinic input]
|
||||||
|
@classmethod
|
||||||
|
_sqlite3.Row.__new__ as pysqlite_row_new
|
||||||
|
|
||||||
|
cursor: object(type='pysqlite_Cursor *', subclass_of='pysqlite_CursorType')
|
||||||
|
data: object(subclass_of='&PyTuple_Type')
|
||||||
|
/
|
||||||
|
|
||||||
|
[clinic start generated code]*/
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
pysqlite_row_new(PyTypeObject *type, PyObject *args, PyObject *kwargs)
|
pysqlite_row_new_impl(PyTypeObject *type, pysqlite_Cursor *cursor,
|
||||||
|
PyObject *data)
|
||||||
|
/*[clinic end generated code: output=10d58b09a819a4c1 input=f6cd7e6e0935828d]*/
|
||||||
{
|
{
|
||||||
pysqlite_Row *self;
|
pysqlite_Row *self;
|
||||||
PyObject* data;
|
|
||||||
pysqlite_Cursor* cursor;
|
|
||||||
|
|
||||||
assert(type != NULL && type->tp_alloc != NULL);
|
assert(type != NULL && type->tp_alloc != NULL);
|
||||||
|
|
||||||
if (!_PyArg_NoKeywords("Row", kwargs))
|
|
||||||
return NULL;
|
|
||||||
if (!PyArg_ParseTuple(args, "OO", &cursor, &data))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (!PyObject_TypeCheck((PyObject*)cursor, pysqlite_CursorType)) {
|
|
||||||
PyErr_SetString(PyExc_TypeError, "instance of cursor required for first argument");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!PyTuple_Check(data)) {
|
|
||||||
PyErr_SetString(PyExc_TypeError, "tuple required for second argument");
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
self = (pysqlite_Row *) type->tp_alloc(type, 0);
|
self = (pysqlite_Row *) type->tp_alloc(type, 0);
|
||||||
if (self == NULL)
|
if (self == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -153,7 +155,15 @@ pysqlite_row_length(pysqlite_Row* self)
|
||||||
return PyTuple_GET_SIZE(self->data);
|
return PyTuple_GET_SIZE(self->data);
|
||||||
}
|
}
|
||||||
|
|
||||||
PyObject* pysqlite_row_keys(pysqlite_Row* self, PyObject *Py_UNUSED(ignored))
|
/*[clinic input]
|
||||||
|
_sqlite3.Row.keys as pysqlite_row_keys
|
||||||
|
|
||||||
|
Returns the keys of the row.
|
||||||
|
[clinic start generated code]*/
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
pysqlite_row_keys_impl(pysqlite_Row *self)
|
||||||
|
/*[clinic end generated code: output=efe3dfb3af6edc07 input=7549a122827c5563]*/
|
||||||
{
|
{
|
||||||
PyObject* list;
|
PyObject* list;
|
||||||
Py_ssize_t nitems, i;
|
Py_ssize_t nitems, i;
|
||||||
|
@ -204,8 +214,7 @@ static PyObject* pysqlite_row_richcompare(pysqlite_Row *self, PyObject *_other,
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyMethodDef row_methods[] = {
|
static PyMethodDef row_methods[] = {
|
||||||
{"keys", (PyCFunction)pysqlite_row_keys, METH_NOARGS,
|
PYSQLITE_ROW_KEYS_METHODDEF
|
||||||
PyDoc_STR("Returns the keys of the row.")},
|
|
||||||
{NULL, NULL}
|
{NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue