| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | preserve | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | pysqlite_cursor_init_impl(pysqlite_Cursor *self, | 
					
						
							|  |  |  |                           pysqlite_Connection *connection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | pysqlite_cursor_init(PyObject *self, PyObject *args, PyObject *kwargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     int return_value = -1; | 
					
						
							|  |  |  |     pysqlite_Connection *connection; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-12 13:27:50 +03:00
										 |  |  |     if ((Py_IS_TYPE(self, clinic_state()->CursorType) || | 
					
						
							|  |  |  |          Py_TYPE(self)->tp_new == clinic_state()->CursorType->tp_new) && | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  |         !_PyArg_NoKeywords("Cursor", kwargs)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("Cursor", PyTuple_GET_SIZE(args), 1, 1)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-06-15 14:47:34 +02:00
										 |  |  |     if (!PyObject_TypeCheck(PyTuple_GET_ITEM(args, 0), clinic_state()->ConnectionType)) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("Cursor", "argument 1", (clinic_state()->ConnectionType)->tp_name, PyTuple_GET_ITEM(args, 0)); | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     connection = (pysqlite_Connection *)PyTuple_GET_ITEM(args, 0); | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_init_impl((pysqlite_Cursor *)self, connection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_execute__doc__, | 
					
						
							|  |  |  | "execute($self, sql, parameters=(), /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Executes a SQL statement."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_EXECUTE_METHODDEF    \
 | 
					
						
							|  |  |  |     {"execute", (PyCFunction)(void(*)(void))pysqlite_cursor_execute, METH_FASTCALL, pysqlite_cursor_execute__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_execute_impl(pysqlite_Cursor *self, PyObject *sql, | 
					
						
							|  |  |  |                              PyObject *parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_execute(pysqlite_Cursor *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     PyObject *sql; | 
					
						
							|  |  |  |     PyObject *parameters = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("execute", nargs, 1, 2)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("execute", "argument 1", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (PyUnicode_READY(args[0]) == -1) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     sql = args[0]; | 
					
						
							|  |  |  |     if (nargs < 2) { | 
					
						
							|  |  |  |         goto skip_optional; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     parameters = args[1]; | 
					
						
							|  |  |  | skip_optional: | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_execute_impl(self, sql, parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_executemany__doc__, | 
					
						
							|  |  |  | "executemany($self, sql, seq_of_parameters, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Repeatedly executes a SQL statement."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_EXECUTEMANY_METHODDEF    \
 | 
					
						
							|  |  |  |     {"executemany", (PyCFunction)(void(*)(void))pysqlite_cursor_executemany, METH_FASTCALL, pysqlite_cursor_executemany__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_executemany_impl(pysqlite_Cursor *self, PyObject *sql, | 
					
						
							|  |  |  |                                  PyObject *seq_of_parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_executemany(pysqlite_Cursor *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     PyObject *sql; | 
					
						
							|  |  |  |     PyObject *seq_of_parameters; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("executemany", nargs, 2, 2)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("executemany", "argument 1", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (PyUnicode_READY(args[0]) == -1) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     sql = args[0]; | 
					
						
							|  |  |  |     seq_of_parameters = args[1]; | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_executemany_impl(self, sql, seq_of_parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_executescript__doc__, | 
					
						
							|  |  |  | "executescript($self, sql_script, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2021-07-14 23:54:37 +02:00
										 |  |  | "Executes multiple SQL statements at once. Non-standard."); | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_EXECUTESCRIPT_METHODDEF    \
 | 
					
						
							|  |  |  |     {"executescript", (PyCFunction)pysqlite_cursor_executescript, METH_O, pysqlite_cursor_executescript__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-08 08:49:44 +03:00
										 |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_executescript_impl(pysqlite_Cursor *self, | 
					
						
							|  |  |  |                                    const char *sql_script); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_executescript(pysqlite_Cursor *self, PyObject *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     const char *sql_script; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!PyUnicode_Check(arg)) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("executescript", "argument", "str", arg); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t sql_script_length; | 
					
						
							|  |  |  |     sql_script = PyUnicode_AsUTF8AndSize(arg, &sql_script_length); | 
					
						
							|  |  |  |     if (sql_script == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(sql_script) != (size_t)sql_script_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_executescript_impl(self, sql_script); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_cursor_fetchone__doc__, | 
					
						
							|  |  |  | "fetchone($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Fetches one row from the resultset."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_FETCHONE_METHODDEF    \
 | 
					
						
							|  |  |  |     {"fetchone", (PyCFunction)pysqlite_cursor_fetchone, METH_NOARGS, pysqlite_cursor_fetchone__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchone_impl(pysqlite_Cursor *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchone(pysqlite_Cursor *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_cursor_fetchone_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_fetchmany__doc__, | 
					
						
							| 
									
										
										
										
											2021-01-14 00:17:33 +01:00
										 |  |  | "fetchmany($self, /, size=1)\n" | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2021-01-14 00:17:33 +01:00
										 |  |  | "Fetches several rows from the resultset.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  size\n" | 
					
						
							|  |  |  | "    The default value is set by the Cursor.arraysize attribute."); | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_FETCHMANY_METHODDEF    \
 | 
					
						
							|  |  |  |     {"fetchmany", (PyCFunction)(void(*)(void))pysqlite_cursor_fetchmany, METH_FASTCALL|METH_KEYWORDS, pysqlite_cursor_fetchmany__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchmany_impl(pysqlite_Cursor *self, int maxrows); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchmany(pysqlite_Cursor *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"size", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "fetchmany", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[1]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0; | 
					
						
							|  |  |  |     int maxrows = self->arraysize; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 1, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_pos; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     maxrows = _PyLong_AsInt(args[0]); | 
					
						
							|  |  |  |     if (maxrows == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_pos: | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_fetchmany_impl(self, maxrows); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_fetchall__doc__, | 
					
						
							|  |  |  | "fetchall($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Fetches all rows from the resultset."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_FETCHALL_METHODDEF    \
 | 
					
						
							|  |  |  |     {"fetchall", (PyCFunction)pysqlite_cursor_fetchall, METH_NOARGS, pysqlite_cursor_fetchall__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchall_impl(pysqlite_Cursor *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_fetchall(pysqlite_Cursor *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_cursor_fetchall_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_setinputsizes__doc__, | 
					
						
							|  |  |  | "setinputsizes($self, sizes, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Required by DB-API. Does nothing in pysqlite."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_SETINPUTSIZES_METHODDEF    \
 | 
					
						
							|  |  |  |     {"setinputsizes", (PyCFunction)pysqlite_cursor_setinputsizes, METH_O, pysqlite_cursor_setinputsizes__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_setoutputsize__doc__, | 
					
						
							|  |  |  | "setoutputsize($self, size, column=None, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Required by DB-API. Does nothing in pysqlite."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_SETOUTPUTSIZE_METHODDEF    \
 | 
					
						
							|  |  |  |     {"setoutputsize", (PyCFunction)(void(*)(void))pysqlite_cursor_setoutputsize, METH_FASTCALL, pysqlite_cursor_setoutputsize__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_setoutputsize_impl(pysqlite_Cursor *self, PyObject *size, | 
					
						
							|  |  |  |                                    PyObject *column); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_cursor_setoutputsize(pysqlite_Cursor *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     PyObject *size; | 
					
						
							|  |  |  |     PyObject *column = Py_None; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("setoutputsize", nargs, 1, 2)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     size = args[0]; | 
					
						
							|  |  |  |     if (nargs < 2) { | 
					
						
							|  |  |  |         goto skip_optional; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     column = args[1]; | 
					
						
							|  |  |  | skip_optional: | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_setoutputsize_impl(self, size, column); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_cursor_close__doc__, | 
					
						
							|  |  |  | "close($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Closes the cursor."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CURSOR_CLOSE_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2021-07-29 11:21:45 +02:00
										 |  |  |     {"close", (PyCFunction)(void(*)(void))pysqlite_cursor_close, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_cursor_close__doc__}, | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-07-29 11:21:45 +02:00
										 |  |  | pysqlite_cursor_close_impl(pysqlite_Cursor *self, PyTypeObject *cls); | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-07-29 11:21:45 +02:00
										 |  |  | pysqlite_cursor_close(pysqlite_Cursor *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-07-29 11:21:45 +02:00
										 |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = { NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {":close", _keywords, 0}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_ParseStackAndKeywords(args, nargs, kwnames, &_parser | 
					
						
							|  |  |  |         )) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = pysqlite_cursor_close_impl(self, cls); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							| 
									
										
										
										
											2021-01-06 00:57:25 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2021-09-12 13:27:50 +03:00
										 |  |  | /*[clinic end generated code: output=3b5328c1619b7626 input=a9049054013a1b77]*/ |