| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | /*[clinic input]
 | 
					
						
							|  |  |  | preserve | 
					
						
							|  |  |  | [clinic start generated code]*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  | static int | 
					
						
							|  |  |  | pysqlite_connection_init_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-09-12 14:27:42 +02:00
										 |  |  |                               const char *database, double timeout, | 
					
						
							| 
									
										
										
										
											2021-11-15 08:50:59 +01:00
										 |  |  |                               int detect_types, const char *isolation_level, | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |                               int check_same_thread, PyObject *factory, | 
					
						
							| 
									
										
										
										
											2021-11-16 15:53:35 +01:00
										 |  |  |                               int cache_size, int uri); | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | pysqlite_connection_init(PyObject *self, PyObject *args, PyObject *kwargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     int return_value = -1; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"database", "timeout", "detect_types", "isolation_level", "check_same_thread", "factory", "cached_statements", "uri", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "Connection", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[8]; | 
					
						
							|  |  |  |     PyObject * const *fastargs; | 
					
						
							|  |  |  |     Py_ssize_t nargs = PyTuple_GET_SIZE(args); | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwargs ? PyDict_GET_SIZE(kwargs) : 0) - 1; | 
					
						
							| 
									
										
										
										
											2021-09-12 14:27:42 +02:00
										 |  |  |     const char *database = NULL; | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |     double timeout = 5.0; | 
					
						
							|  |  |  |     int detect_types = 0; | 
					
						
							| 
									
										
										
										
											2021-11-15 08:50:59 +01:00
										 |  |  |     const char *isolation_level = ""; | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |     int check_same_thread = 1; | 
					
						
							|  |  |  |     PyObject *factory = (PyObject*)clinic_state()->ConnectionType; | 
					
						
							| 
									
										
										
										
											2021-11-16 15:53:35 +01:00
										 |  |  |     int cache_size = 128; | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |     int uri = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     fastargs = _PyArg_UnpackKeywords(_PyTuple_CAST(args)->ob_item, nargs, kwargs, NULL, &_parser, 1, 8, 0, argsbuf); | 
					
						
							|  |  |  |     if (!fastargs) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-09-12 14:27:42 +02:00
										 |  |  |     if (!clinic_fsconverter(fastargs[0], &database)) { | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_pos; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[1]) { | 
					
						
							|  |  |  |         if (PyFloat_CheckExact(fastargs[1])) { | 
					
						
							|  |  |  |             timeout = PyFloat_AS_DOUBLE(fastargs[1]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             timeout = PyFloat_AsDouble(fastargs[1]); | 
					
						
							|  |  |  |             if (timeout == -1.0 && PyErr_Occurred()) { | 
					
						
							|  |  |  |                 goto exit; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[2]) { | 
					
						
							|  |  |  |         detect_types = _PyLong_AsInt(fastargs[2]); | 
					
						
							|  |  |  |         if (detect_types == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[3]) { | 
					
						
							| 
									
										
										
										
											2021-11-18 10:18:09 +01:00
										 |  |  |         if (!isolation_level_converter(fastargs[3], &isolation_level)) { | 
					
						
							| 
									
										
										
										
											2021-11-15 08:50:59 +01:00
										 |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[4]) { | 
					
						
							|  |  |  |         check_same_thread = _PyLong_AsInt(fastargs[4]); | 
					
						
							|  |  |  |         if (check_same_thread == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[5]) { | 
					
						
							|  |  |  |         factory = fastargs[5]; | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (fastargs[6]) { | 
					
						
							| 
									
										
										
										
											2021-11-16 15:53:35 +01:00
										 |  |  |         cache_size = _PyLong_AsInt(fastargs[6]); | 
					
						
							|  |  |  |         if (cache_size == -1 && PyErr_Occurred()) { | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_pos; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     uri = PyObject_IsTrue(fastargs[7]); | 
					
						
							|  |  |  |     if (uri < 0) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_pos: | 
					
						
							| 
									
										
										
										
											2021-11-16 15:53:35 +01:00
										 |  |  |     return_value = pysqlite_connection_init_impl((pysqlite_Connection *)self, database, timeout, detect_types, isolation_level, check_same_thread, factory, cache_size, uri); | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							| 
									
										
										
										
											2021-09-12 14:27:42 +02:00
										 |  |  |     /* Cleanup for database */ | 
					
						
							|  |  |  |     PyMem_Free((void *)database); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-20 21:24:00 +02:00
										 |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_cursor__doc__, | 
					
						
							|  |  |  | "cursor($self, /, factory=<unrepresentable>)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Return a cursor for the connection."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_CURSOR_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"cursor", _PyCFunction_CAST(pysqlite_connection_cursor), METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_cursor__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_cursor_impl(pysqlite_Connection *self, PyObject *factory); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_cursor(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"factory", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "cursor", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[1]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0; | 
					
						
							|  |  |  |     PyObject *factory = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 1, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_pos; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     factory = args[0]; | 
					
						
							|  |  |  | skip_optional_pos: | 
					
						
							|  |  |  |     return_value = pysqlite_connection_cursor_impl(self, factory); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-15 02:02:56 +02:00
										 |  |  | PyDoc_STRVAR(blobopen__doc__, | 
					
						
							|  |  |  | "blobopen($self, table, column, row, /, *, readonly=False, name=\'main\')\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Open and return a BLOB object.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  table\n" | 
					
						
							|  |  |  | "    Table name.\n" | 
					
						
							|  |  |  | "  column\n" | 
					
						
							|  |  |  | "    Column name.\n" | 
					
						
							|  |  |  | "  row\n" | 
					
						
							|  |  |  | "    Row index.\n" | 
					
						
							|  |  |  | "  readonly\n" | 
					
						
							|  |  |  | "    Open the BLOB without write permissions.\n" | 
					
						
							|  |  |  | "  name\n" | 
					
						
							|  |  |  | "    Database name."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define BLOBOPEN_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"blobopen", _PyCFunction_CAST(blobopen), METH_FASTCALL|METH_KEYWORDS, blobopen__doc__}, | 
					
						
							| 
									
										
										
										
											2022-04-15 02:02:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | blobopen_impl(pysqlite_Connection *self, const char *table, const char *col, | 
					
						
							|  |  |  |               int row, int readonly, const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | blobopen(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"", "", "", "readonly", "name", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "blobopen", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[5]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 3; | 
					
						
							|  |  |  |     const char *table; | 
					
						
							|  |  |  |     const char *col; | 
					
						
							|  |  |  |     int row; | 
					
						
							|  |  |  |     int readonly = 0; | 
					
						
							|  |  |  |     const char *name = "main"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 3, 3, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("blobopen", "argument 1", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t table_length; | 
					
						
							|  |  |  |     table = PyUnicode_AsUTF8AndSize(args[0], &table_length); | 
					
						
							|  |  |  |     if (table == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(table) != (size_t)table_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[1])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("blobopen", "argument 2", "str", args[1]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t col_length; | 
					
						
							|  |  |  |     col = PyUnicode_AsUTF8AndSize(args[1], &col_length); | 
					
						
							|  |  |  |     if (col == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(col) != (size_t)col_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     row = _PyLong_AsInt(args[2]); | 
					
						
							|  |  |  |     if (row == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_kwonly; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (args[3]) { | 
					
						
							|  |  |  |         readonly = _PyLong_AsInt(args[3]); | 
					
						
							|  |  |  |         if (readonly == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_kwonly; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[4])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("blobopen", "argument 'name'", "str", args[4]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[4], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_kwonly: | 
					
						
							|  |  |  |     return_value = blobopen_impl(self, table, col, row, readonly, name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_close__doc__, | 
					
						
							|  |  |  | "close($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Closes the connection."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_CLOSE_METHODDEF    \
 | 
					
						
							|  |  |  |     {"close", (PyCFunction)pysqlite_connection_close, METH_NOARGS, pysqlite_connection_close__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_close_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_close(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_close_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_commit__doc__, | 
					
						
							|  |  |  | "commit($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Commit the current transaction."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_COMMIT_METHODDEF    \
 | 
					
						
							|  |  |  |     {"commit", (PyCFunction)pysqlite_connection_commit, METH_NOARGS, pysqlite_connection_commit__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_commit_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_commit(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_commit_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_rollback__doc__, | 
					
						
							|  |  |  | "rollback($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Roll back the current transaction."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_ROLLBACK_METHODDEF    \
 | 
					
						
							|  |  |  |     {"rollback", (PyCFunction)pysqlite_connection_rollback, METH_NOARGS, pysqlite_connection_rollback__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_rollback_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_rollback(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_rollback_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_create_function__doc__, | 
					
						
							|  |  |  | "create_function($self, /, name, narg, func, *, deterministic=False)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Creates a new function."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_CREATE_FUNCTION_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"create_function", _PyCFunction_CAST(pysqlite_connection_create_function), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_create_function__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_create_function_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                          PyTypeObject *cls, const char *name, | 
					
						
							|  |  |  |                                          int narg, PyObject *func, | 
					
						
							|  |  |  |                                          int deterministic); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_create_function(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"name", "narg", "func", "deterministic", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "create_function", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[4]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 3; | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |     const char *name; | 
					
						
							|  |  |  |     int narg; | 
					
						
							|  |  |  |     PyObject *func; | 
					
						
							|  |  |  |     int deterministic = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 3, 3, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("create_function", "argument 'name'", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[0], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     narg = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |     if (narg == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     func = args[2]; | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_kwonly; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     deterministic = PyObject_IsTrue(args[3]); | 
					
						
							|  |  |  |     if (deterministic < 0) { | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  | skip_optional_kwonly: | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_create_function_impl(self, cls, name, narg, func, deterministic); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  | #if defined(HAVE_WINDOW_FUNCTIONS)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(create_window_function__doc__, | 
					
						
							|  |  |  | "create_window_function($self, name, num_params, aggregate_class, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Creates or redefines an aggregate window function. Non-standard.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  name\n" | 
					
						
							|  |  |  | "    The name of the SQL aggregate window function to be created or\n" | 
					
						
							|  |  |  | "    redefined.\n" | 
					
						
							|  |  |  | "  num_params\n" | 
					
						
							|  |  |  | "    The number of arguments the step and inverse methods takes.\n" | 
					
						
							|  |  |  | "  aggregate_class\n" | 
					
						
							|  |  |  | "    A class with step(), finalize(), value(), and inverse() methods.\n" | 
					
						
							|  |  |  | "    Set to None to clear the window function."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CREATE_WINDOW_FUNCTION_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"create_window_function", _PyCFunction_CAST(create_window_function), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, create_window_function__doc__}, | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | create_window_function_impl(pysqlite_Connection *self, PyTypeObject *cls, | 
					
						
							|  |  |  |                             const char *name, int num_params, | 
					
						
							|  |  |  |                             PyObject *aggregate_class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | create_window_function(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"", "", "", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "create_window_function", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[3]; | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  |     const char *name; | 
					
						
							|  |  |  |     int num_params; | 
					
						
							|  |  |  |     PyObject *aggregate_class; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 3, 3, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("create_window_function", "argument 1", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[0], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     num_params = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |     if (num_params == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     aggregate_class = args[2]; | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  |     return_value = create_window_function_impl(self, cls, name, num_params, aggregate_class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* defined(HAVE_WINDOW_FUNCTIONS) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_create_aggregate__doc__, | 
					
						
							|  |  |  | "create_aggregate($self, /, name, n_arg, aggregate_class)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Creates a new aggregate."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_CREATE_AGGREGATE_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"create_aggregate", _PyCFunction_CAST(pysqlite_connection_create_aggregate), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_create_aggregate__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_create_aggregate_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                           PyTypeObject *cls, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |                                           const char *name, int n_arg, | 
					
						
							|  |  |  |                                           PyObject *aggregate_class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_create_aggregate(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"name", "n_arg", "aggregate_class", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "create_aggregate", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[3]; | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |     const char *name; | 
					
						
							|  |  |  |     int n_arg; | 
					
						
							|  |  |  |     PyObject *aggregate_class; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 3, 3, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("create_aggregate", "argument 'name'", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[0], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     n_arg = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |     if (n_arg == -1 && PyErr_Occurred()) { | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     aggregate_class = args[2]; | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_create_aggregate_impl(self, cls, name, n_arg, aggregate_class); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_set_authorizer__doc__, | 
					
						
							|  |  |  | "set_authorizer($self, /, authorizer_callback)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Sets authorizer callback."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_SET_AUTHORIZER_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"set_authorizer", _PyCFunction_CAST(pysqlite_connection_set_authorizer), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_set_authorizer__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_set_authorizer_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                         PyTypeObject *cls, | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |                                         PyObject *callable); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_set_authorizer(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"authorizer_callback", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "set_authorizer", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[1]; | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |     PyObject *callable; | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     callable = args[0]; | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_set_authorizer_impl(self, cls, callable); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_set_progress_handler__doc__, | 
					
						
							|  |  |  | "set_progress_handler($self, /, progress_handler, n)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Sets progress handler callback."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_SET_PROGRESS_HANDLER_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"set_progress_handler", _PyCFunction_CAST(pysqlite_connection_set_progress_handler), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_set_progress_handler__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_set_progress_handler_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                               PyTypeObject *cls, | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |                                               PyObject *callable, int n); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_set_progress_handler(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"progress_handler", "n", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "set_progress_handler", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[2]; | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |     PyObject *callable; | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |     int n; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     callable = args[0]; | 
					
						
							|  |  |  |     n = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |     if (n == -1 && PyErr_Occurred()) { | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_set_progress_handler_impl(self, cls, callable, n); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_set_trace_callback__doc__, | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | "set_trace_callback($self, /, trace_callback)\n" | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Sets a trace callback called for each SQL statement (passed as unicode)."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_SET_TRACE_CALLBACK_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"set_trace_callback", _PyCFunction_CAST(pysqlite_connection_set_trace_callback), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_set_trace_callback__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_set_trace_callback_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                             PyTypeObject *cls, | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |                                             PyObject *callable); | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_set_trace_callback(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"trace_callback", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "set_trace_callback", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[1]; | 
					
						
							| 
									
										
										
										
											2021-09-07 13:43:44 +02:00
										 |  |  |     PyObject *callable; | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     callable = args[0]; | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_set_trace_callback_impl(self, cls, callable); | 
					
						
							| 
									
										
										
										
											2020-12-19 00:41:33 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 11:30:37 +02:00
										 |  |  | #if defined(PY_SQLITE_ENABLE_LOAD_EXTENSION)
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_enable_load_extension__doc__, | 
					
						
							|  |  |  | "enable_load_extension($self, enable, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Enable dynamic loading of SQLite extension modules."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_ENABLE_LOAD_EXTENSION_METHODDEF    \
 | 
					
						
							|  |  |  |     {"enable_load_extension", (PyCFunction)pysqlite_connection_enable_load_extension, METH_O, pysqlite_connection_enable_load_extension__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_enable_load_extension_impl(pysqlite_Connection *self, | 
					
						
							|  |  |  |                                                int onoff); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_enable_load_extension(pysqlite_Connection *self, PyObject *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     int onoff; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     onoff = _PyLong_AsInt(arg); | 
					
						
							|  |  |  |     if (onoff == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = pysqlite_connection_enable_load_extension_impl(self, onoff); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 11:30:37 +02:00
										 |  |  | #endif /* defined(PY_SQLITE_ENABLE_LOAD_EXTENSION) */
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 11:30:37 +02:00
										 |  |  | #if defined(PY_SQLITE_ENABLE_LOAD_EXTENSION)
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_load_extension__doc__, | 
					
						
							|  |  |  | "load_extension($self, name, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Load SQLite extension module."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_LOAD_EXTENSION_METHODDEF    \
 | 
					
						
							|  |  |  |     {"load_extension", (PyCFunction)pysqlite_connection_load_extension, METH_O, pysqlite_connection_load_extension__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_load_extension_impl(pysqlite_Connection *self, | 
					
						
							|  |  |  |                                         const char *extension_name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_load_extension(pysqlite_Connection *self, PyObject *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     const char *extension_name; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!PyUnicode_Check(arg)) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("load_extension", "argument", "str", arg); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t extension_name_length; | 
					
						
							|  |  |  |     extension_name = PyUnicode_AsUTF8AndSize(arg, &extension_name_length); | 
					
						
							|  |  |  |     if (extension_name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(extension_name) != (size_t)extension_name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = pysqlite_connection_load_extension_impl(self, extension_name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 11:30:37 +02:00
										 |  |  | #endif /* defined(PY_SQLITE_ENABLE_LOAD_EXTENSION) */
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_execute__doc__, | 
					
						
							|  |  |  | "execute($self, sql, parameters=<unrepresentable>, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Executes an SQL statement."); | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_EXECUTE_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"execute", _PyCFunction_CAST(pysqlite_connection_execute), METH_FASTCALL, pysqlite_connection_execute__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_execute_impl(pysqlite_Connection *self, PyObject *sql, | 
					
						
							|  |  |  |                                  PyObject *parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_execute(pysqlite_Connection *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_connection_execute_impl(self, sql, parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_executemany__doc__, | 
					
						
							|  |  |  | "executemany($self, sql, parameters, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Repeatedly executes an SQL statement."); | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_EXECUTEMANY_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"executemany", _PyCFunction_CAST(pysqlite_connection_executemany), METH_FASTCALL, pysqlite_connection_executemany__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_executemany_impl(pysqlite_Connection *self, | 
					
						
							|  |  |  |                                      PyObject *sql, PyObject *parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_executemany(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     PyObject *sql; | 
					
						
							|  |  |  |     PyObject *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]; | 
					
						
							|  |  |  |     parameters = args[1]; | 
					
						
							|  |  |  |     return_value = pysqlite_connection_executemany_impl(self, sql, parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_executescript__doc__, | 
					
						
							|  |  |  | "executescript($self, sql_script, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Executes multiple SQL statements at once."); | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_EXECUTESCRIPT_METHODDEF    \
 | 
					
						
							|  |  |  |     {"executescript", (PyCFunction)pysqlite_connection_executescript, METH_O, pysqlite_connection_executescript__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_interrupt__doc__, | 
					
						
							|  |  |  | "interrupt($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Abort any pending database operation."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_INTERRUPT_METHODDEF    \
 | 
					
						
							|  |  |  |     {"interrupt", (PyCFunction)pysqlite_connection_interrupt, METH_NOARGS, pysqlite_connection_interrupt__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_interrupt_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_interrupt(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_interrupt_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_iterdump__doc__, | 
					
						
							|  |  |  | "iterdump($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Returns iterator to the dump of the database in an SQL text format."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_ITERDUMP_METHODDEF    \
 | 
					
						
							|  |  |  |     {"iterdump", (PyCFunction)pysqlite_connection_iterdump, METH_NOARGS, pysqlite_connection_iterdump__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_iterdump_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_iterdump(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_iterdump_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_backup__doc__, | 
					
						
							| 
									
										
										
										
											2021-02-11 00:04:02 +01:00
										 |  |  | "backup($self, /, target, *, pages=-1, progress=None, name=\'main\',\n" | 
					
						
							|  |  |  | "       sleep=0.25)\n" | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Makes a backup of the database."); | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_BACKUP_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"backup", _PyCFunction_CAST(pysqlite_connection_backup), METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_backup__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_backup_impl(pysqlite_Connection *self, | 
					
						
							|  |  |  |                                 pysqlite_Connection *target, int pages, | 
					
						
							|  |  |  |                                 PyObject *progress, const char *name, | 
					
						
							|  |  |  |                                 double sleep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_backup(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"target", "pages", "progress", "name", "sleep", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "backup", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[5]; | 
					
						
							| 
									
										
										
										
											2021-02-11 00:04:02 +01:00
										 |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1; | 
					
						
							|  |  |  |     pysqlite_Connection *target; | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  |     int pages = -1; | 
					
						
							|  |  |  |     PyObject *progress = Py_None; | 
					
						
							|  |  |  |     const char *name = "main"; | 
					
						
							|  |  |  |     double sleep = 0.25; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-11 00:04:02 +01:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf); | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-06-15 14:47:34 +02:00
										 |  |  |     if (!PyObject_TypeCheck(args[0], clinic_state()->ConnectionType)) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("backup", "argument 'target'", (clinic_state()->ConnectionType)->tp_name, args[0]); | 
					
						
							| 
									
										
										
										
											2021-02-11 00:04:02 +01:00
										 |  |  |         goto exit; | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-11 00:04:02 +01:00
										 |  |  |     target = (pysqlite_Connection *)args[0]; | 
					
						
							| 
									
										
										
										
											2020-12-27 09:32:18 +01:00
										 |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_kwonly; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (args[1]) { | 
					
						
							|  |  |  |         pages = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |         if (pages == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_kwonly; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (args[2]) { | 
					
						
							|  |  |  |         progress = args[2]; | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_kwonly; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (args[3]) { | 
					
						
							|  |  |  |         if (!PyUnicode_Check(args[3])) { | 
					
						
							|  |  |  |             _PyArg_BadArgument("backup", "argument 'name'", "str", args[3]); | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Py_ssize_t name_length; | 
					
						
							|  |  |  |         name = PyUnicode_AsUTF8AndSize(args[3], &name_length); | 
					
						
							|  |  |  |         if (name == NULL) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |             PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!--noptargs) { | 
					
						
							|  |  |  |             goto skip_optional_kwonly; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (PyFloat_CheckExact(args[4])) { | 
					
						
							|  |  |  |         sleep = PyFloat_AS_DOUBLE(args[4]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         sleep = PyFloat_AsDouble(args[4]); | 
					
						
							|  |  |  |         if (sleep == -1.0 && PyErr_Occurred()) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_kwonly: | 
					
						
							|  |  |  |     return_value = pysqlite_connection_backup_impl(self, target, pages, progress, name, sleep); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_create_collation__doc__, | 
					
						
							|  |  |  | "create_collation($self, name, callback, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2022-03-08 05:18:41 +01:00
										 |  |  | "Creates a collation function."); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_CREATE_COLLATION_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"create_collation", _PyCFunction_CAST(pysqlite_connection_create_collation), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, pysqlite_connection_create_collation__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_create_collation_impl(pysqlite_Connection *self, | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |                                           PyTypeObject *cls, | 
					
						
							| 
									
										
										
										
											2021-07-29 09:47:56 +02:00
										 |  |  |                                           const char *name, | 
					
						
							|  |  |  |                                           PyObject *callable); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  | pysqlite_connection_create_collation(pysqlite_Connection *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     static const char * const _keywords[] = {"", "", NULL}; | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "create_collation", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[2]; | 
					
						
							| 
									
										
										
										
											2021-07-29 09:47:56 +02:00
										 |  |  |     const char *name; | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |     PyObject *callable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 2, 2, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("create_collation", "argument 1", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[0], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-04-30 13:15:02 +03:00
										 |  |  |     callable = args[1]; | 
					
						
							| 
									
										
										
										
											2021-10-19 15:44:45 +02:00
										 |  |  |     return_value = pysqlite_connection_create_collation_impl(self, cls, name, callable); | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-05 16:15:25 +02:00
										 |  |  | #if defined(PY_SQLITE_HAVE_SERIALIZE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(serialize__doc__, | 
					
						
							|  |  |  | "serialize($self, /, *, name=\'main\')\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Serialize a database into a byte string.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  name\n" | 
					
						
							|  |  |  | "    Which database to serialize.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "For an ordinary on-disk database file, the serialization is just a copy of the\n" | 
					
						
							|  |  |  | "disk file. For an in-memory database or a \"temp\" database, the serialization is\n" | 
					
						
							|  |  |  | "the same sequence of bytes which would be written to disk if that database\n" | 
					
						
							|  |  |  | "were backed up to disk."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SERIALIZE_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"serialize", _PyCFunction_CAST(serialize), METH_FASTCALL|METH_KEYWORDS, serialize__doc__}, | 
					
						
							| 
									
										
										
										
											2022-04-05 16:15:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | serialize_impl(pysqlite_Connection *self, const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | serialize(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"name", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "serialize", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[1]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0; | 
					
						
							|  |  |  |     const char *name = "main"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 0, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_kwonly; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("serialize", "argument 'name'", "str", args[0]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[0], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_kwonly: | 
					
						
							|  |  |  |     return_value = serialize_impl(self, name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* defined(PY_SQLITE_HAVE_SERIALIZE) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(PY_SQLITE_HAVE_SERIALIZE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(deserialize__doc__, | 
					
						
							|  |  |  | "deserialize($self, data, /, *, name=\'main\')\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Load a serialized database.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  data\n" | 
					
						
							|  |  |  | "    The serialized database content.\n" | 
					
						
							|  |  |  | "  name\n" | 
					
						
							|  |  |  | "    Which database to reopen with the deserialization.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "The deserialize interface causes the database connection to disconnect from the\n" | 
					
						
							|  |  |  | "target database, and then reopen it as an in-memory database based on the given\n" | 
					
						
							|  |  |  | "serialized data.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "The deserialize interface will fail with SQLITE_BUSY if the database is\n" | 
					
						
							|  |  |  | "currently in a read transaction or is involved in a backup operation."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DESERIALIZE_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"deserialize", _PyCFunction_CAST(deserialize), METH_FASTCALL|METH_KEYWORDS, deserialize__doc__}, | 
					
						
							| 
									
										
										
										
											2022-04-05 16:15:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | deserialize_impl(pysqlite_Connection *self, Py_buffer *data, | 
					
						
							|  |  |  |                  const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | deserialize(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     static const char * const _keywords[] = {"", "name", NULL}; | 
					
						
							|  |  |  |     static _PyArg_Parser _parser = {NULL, _keywords, "deserialize", 0}; | 
					
						
							|  |  |  |     PyObject *argsbuf[2]; | 
					
						
							|  |  |  |     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 1; | 
					
						
							|  |  |  |     Py_buffer data = {NULL, NULL}; | 
					
						
							|  |  |  |     const char *name = "main"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 1, 1, 0, argsbuf); | 
					
						
							|  |  |  |     if (!args) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (PyUnicode_Check(args[0])) { | 
					
						
							|  |  |  |         Py_ssize_t len; | 
					
						
							|  |  |  |         const char *ptr = PyUnicode_AsUTF8AndSize(args[0], &len); | 
					
						
							|  |  |  |         if (ptr == NULL) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         PyBuffer_FillInfo(&data, args[0], (void *)ptr, len, 1, 0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { /* any bytes-like object */ | 
					
						
							|  |  |  |         if (PyObject_GetBuffer(args[0], &data, PyBUF_SIMPLE) != 0) { | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!PyBuffer_IsContiguous(&data, 'C')) { | 
					
						
							|  |  |  |             _PyArg_BadArgument("deserialize", "argument 1", "contiguous buffer", args[0]); | 
					
						
							|  |  |  |             goto exit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!noptargs) { | 
					
						
							|  |  |  |         goto skip_optional_kwonly; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!PyUnicode_Check(args[1])) { | 
					
						
							|  |  |  |         _PyArg_BadArgument("deserialize", "argument 'name'", "str", args[1]); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Py_ssize_t name_length; | 
					
						
							|  |  |  |     name = PyUnicode_AsUTF8AndSize(args[1], &name_length); | 
					
						
							|  |  |  |     if (name == NULL) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (strlen(name) != (size_t)name_length) { | 
					
						
							|  |  |  |         PyErr_SetString(PyExc_ValueError, "embedded null character"); | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | skip_optional_kwonly: | 
					
						
							|  |  |  |     return_value = deserialize_impl(self, &data, name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     /* Cleanup for data */ | 
					
						
							|  |  |  |     if (data.obj) { | 
					
						
							|  |  |  |        PyBuffer_Release(&data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* defined(PY_SQLITE_HAVE_SERIALIZE) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | PyDoc_STRVAR(pysqlite_connection_enter__doc__, | 
					
						
							|  |  |  | "__enter__($self, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Called when the connection is used as a context manager.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Returns itself as a convenience to the caller."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_ENTER_METHODDEF    \
 | 
					
						
							|  |  |  |     {"__enter__", (PyCFunction)pysqlite_connection_enter, METH_NOARGS, pysqlite_connection_enter__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_enter_impl(pysqlite_Connection *self); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_enter(pysqlite_Connection *self, PyObject *Py_UNUSED(ignored)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return pysqlite_connection_enter_impl(self); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(pysqlite_connection_exit__doc__, | 
					
						
							|  |  |  | "__exit__($self, type, value, traceback, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Called when the connection is used as a context manager.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "If there was any exception, a rollback takes place; otherwise we commit."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PYSQLITE_CONNECTION_EXIT_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"__exit__", _PyCFunction_CAST(pysqlite_connection_exit), METH_FASTCALL, pysqlite_connection_exit__doc__}, | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_exit_impl(pysqlite_Connection *self, PyObject *exc_type, | 
					
						
							|  |  |  |                               PyObject *exc_value, PyObject *exc_tb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | pysqlite_connection_exit(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     PyObject *exc_type; | 
					
						
							|  |  |  |     PyObject *exc_value; | 
					
						
							|  |  |  |     PyObject *exc_tb; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("__exit__", nargs, 3, 3)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     exc_type = args[0]; | 
					
						
							|  |  |  |     exc_value = args[1]; | 
					
						
							|  |  |  |     exc_tb = args[2]; | 
					
						
							|  |  |  |     return_value = pysqlite_connection_exit_impl(self, exc_type, exc_value, exc_tb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-01 23:50:53 +01:00
										 |  |  | PyDoc_STRVAR(setlimit__doc__, | 
					
						
							|  |  |  | "setlimit($self, category, limit, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Set connection run-time limits.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  category\n" | 
					
						
							|  |  |  | "    The limit category to be set.\n" | 
					
						
							|  |  |  | "  limit\n" | 
					
						
							|  |  |  | "    The new limit. If the new limit is a negative number, the limit is\n" | 
					
						
							|  |  |  | "    unchanged.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Attempts to increase a limit above its hard upper bound are silently truncated\n" | 
					
						
							|  |  |  | "to the hard upper bound. Regardless of whether or not the limit was changed,\n" | 
					
						
							|  |  |  | "the prior value of the limit is returned."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SETLIMIT_METHODDEF    \
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  |     {"setlimit", _PyCFunction_CAST(setlimit), METH_FASTCALL, setlimit__doc__}, | 
					
						
							| 
									
										
										
										
											2021-11-01 23:50:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | setlimit_impl(pysqlite_Connection *self, int category, int limit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | setlimit(pysqlite_Connection *self, PyObject *const *args, Py_ssize_t nargs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     int category; | 
					
						
							|  |  |  |     int limit; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PyArg_CheckPositional("setlimit", nargs, 2, 2)) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     category = _PyLong_AsInt(args[0]); | 
					
						
							|  |  |  |     if (category == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     limit = _PyLong_AsInt(args[1]); | 
					
						
							|  |  |  |     if (limit == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = setlimit_impl(self, category, limit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(getlimit__doc__, | 
					
						
							|  |  |  | "getlimit($self, category, /)\n" | 
					
						
							|  |  |  | "--\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "Get connection run-time limits.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "  category\n" | 
					
						
							|  |  |  | "    The limit category to be queried."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GETLIMIT_METHODDEF    \
 | 
					
						
							|  |  |  |     {"getlimit", (PyCFunction)getlimit, METH_O, getlimit__doc__}, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | getlimit_impl(pysqlite_Connection *self, int category); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject * | 
					
						
							|  |  |  | getlimit(pysqlite_Connection *self, PyObject *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     PyObject *return_value = NULL; | 
					
						
							|  |  |  |     int category; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     category = _PyLong_AsInt(arg); | 
					
						
							|  |  |  |     if (category == -1 && PyErr_Occurred()) { | 
					
						
							|  |  |  |         goto exit; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return_value = getlimit_impl(self, category); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit: | 
					
						
							|  |  |  |     return return_value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-12 02:55:59 +02:00
										 |  |  | #ifndef CREATE_WINDOW_FUNCTION_METHODDEF
 | 
					
						
							|  |  |  |     #define CREATE_WINDOW_FUNCTION_METHODDEF
 | 
					
						
							|  |  |  | #endif /* !defined(CREATE_WINDOW_FUNCTION_METHODDEF) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-18 15:25:35 +01:00
										 |  |  | #ifndef PYSQLITE_CONNECTION_ENABLE_LOAD_EXTENSION_METHODDEF
 | 
					
						
							|  |  |  |     #define PYSQLITE_CONNECTION_ENABLE_LOAD_EXTENSION_METHODDEF
 | 
					
						
							|  |  |  | #endif /* !defined(PYSQLITE_CONNECTION_ENABLE_LOAD_EXTENSION_METHODDEF) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef PYSQLITE_CONNECTION_LOAD_EXTENSION_METHODDEF
 | 
					
						
							|  |  |  |     #define PYSQLITE_CONNECTION_LOAD_EXTENSION_METHODDEF
 | 
					
						
							|  |  |  | #endif /* !defined(PYSQLITE_CONNECTION_LOAD_EXTENSION_METHODDEF) */
 | 
					
						
							| 
									
										
										
										
											2022-04-05 16:15:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef SERIALIZE_METHODDEF
 | 
					
						
							|  |  |  |     #define SERIALIZE_METHODDEF
 | 
					
						
							|  |  |  | #endif /* !defined(SERIALIZE_METHODDEF) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef DESERIALIZE_METHODDEF
 | 
					
						
							|  |  |  |     #define DESERIALIZE_METHODDEF
 | 
					
						
							|  |  |  | #endif /* !defined(DESERIALIZE_METHODDEF) */
 | 
					
						
							| 
									
										
										
										
											2022-05-03 20:25:41 +02:00
										 |  |  | /*[clinic end generated code: output=d21767843c480a10 input=a9049054013a1b77]*/ |