mirror of https://github.com/python/cpython
60 lines
1.8 KiB
C
60 lines
1.8 KiB
C
/*[clinic input]
|
|
preserve
|
|
[clinic start generated code]*/
|
|
|
|
#include "pycore_modsupport.h" // _PyArg_CheckPositional()
|
|
|
|
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;
|
|
PyTypeObject *base_tp = clinic_state()->RowType;
|
|
pysqlite_Cursor *cursor;
|
|
PyObject *data;
|
|
|
|
if ((type == base_tp || type->tp_init == base_tp->tp_init) &&
|
|
!_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), clinic_state()->CursorType)) {
|
|
_PyArg_BadArgument("Row", "argument 1", (clinic_state()->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=788bf817acc02b8e input=a9049054013a1b77]*/
|