blob: 1841c768563f84d160181f7fd90c5c8926be6319 [file] [log] [blame]
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001/* connection.c - the connection type
2 *
Florent Xiclunac934f322010-09-03 23:47:32 +00003 * Copyright (C) 2004-2010 Gerhard Häring <gh@ghaering.de>
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00004 *
5 * This file is part of pysqlite.
Victor Stinner86999502010-05-19 01:27:23 +00006 *
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00007 * This software is provided 'as-is', without any express or implied
8 * warranty. In no event will the authors be held liable for any damages
9 * arising from the use of this software.
10 *
11 * Permission is granted to anyone to use this software for any purpose,
12 * including commercial applications, and to alter it and redistribute it
13 * freely, subject to the following restrictions:
14 *
15 * 1. The origin of this software must not be misrepresented; you must not
16 * claim that you wrote the original software. If you use this software
17 * in a product, an acknowledgment in the product documentation would be
18 * appreciated but is not required.
19 * 2. Altered source versions must be plainly marked as such, and must not be
20 * misrepresented as being the original software.
21 * 3. This notice may not be removed or altered from any source distribution.
22 */
23
24#include "cache.h"
25#include "module.h"
R. David Murrayd35251d2010-06-01 01:32:12 +000026#include "structmember.h"
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000027#include "connection.h"
28#include "statement.h"
29#include "cursor.h"
30#include "prepare_protocol.h"
31#include "util.h"
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000032
33#include "pythread.h"
34
Gerhard Häringe7ea7452008-03-29 00:45:29 +000035#define ACTION_FINALIZE 1
36#define ACTION_RESET 2
37
Gerhard Häringf9cee222010-03-05 15:20:03 +000038#if SQLITE_VERSION_NUMBER >= 3003008
39#ifndef SQLITE_OMIT_LOAD_EXTENSION
40#define HAVE_LOAD_EXTENSION
41#endif
42#endif
43
Martin v. Löwise75fc142013-11-07 18:46:53 +010044_Py_IDENTIFIER(cursor);
45
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +000046static int pysqlite_connection_set_isolation_level(pysqlite_Connection* self, PyObject* isolation_level);
Gerhard Häringf9cee222010-03-05 15:20:03 +000047static void _pysqlite_drop_unused_cursor_references(pysqlite_Connection* self);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000048
Thomas Wouters0e3f5912006-08-11 14:57:12 +000049
Benjamin Petersond7b03282008-09-13 15:58:53 +000050static void _sqlite3_result_error(sqlite3_context* ctx, const char* errmsg, int len)
Thomas Wouters0e3f5912006-08-11 14:57:12 +000051{
52 /* in older SQLite versions, calling sqlite3_result_error in callbacks
53 * triggers a bug in SQLite that leads either to irritating results or
54 * segfaults, depending on the SQLite version */
55#if SQLITE_VERSION_NUMBER >= 3003003
56 sqlite3_result_error(ctx, errmsg, len);
57#else
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +000058 PyErr_SetString(pysqlite_OperationalError, errmsg);
Thomas Wouters0e3f5912006-08-11 14:57:12 +000059#endif
60}
61
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +000062int pysqlite_connection_init(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000063{
Antoine Pitrou902fc8b2013-02-10 00:02:44 +010064 static char *kwlist[] = {
65 "database", "timeout", "detect_types", "isolation_level",
66 "check_same_thread", "factory", "cached_statements", "uri",
67 NULL
68 };
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000069
70 char* database;
71 int detect_types = 0;
72 PyObject* isolation_level = NULL;
73 PyObject* factory = NULL;
74 int check_same_thread = 1;
75 int cached_statements = 100;
Antoine Pitrou902fc8b2013-02-10 00:02:44 +010076 int uri = 0;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000077 double timeout = 5.0;
78 int rc;
79
Antoine Pitrou902fc8b2013-02-10 00:02:44 +010080 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s|diOiOip", kwlist,
81 &database, &timeout, &detect_types,
82 &isolation_level, &check_same_thread,
83 &factory, &cached_statements, &uri))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000084 {
Gerhard Häringe7ea7452008-03-29 00:45:29 +000085 return -1;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000086 }
87
Gerhard Häringf9cee222010-03-05 15:20:03 +000088 self->initialized = 1;
89
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000090 self->begin_statement = NULL;
91
92 self->statement_cache = NULL;
Thomas Wouters477c8d52006-05-27 19:21:47 +000093 self->statements = NULL;
Gerhard Häringf9cee222010-03-05 15:20:03 +000094 self->cursors = NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +000095
96 Py_INCREF(Py_None);
97 self->row_factory = Py_None;
98
99 Py_INCREF(&PyUnicode_Type);
100 self->text_factory = (PyObject*)&PyUnicode_Type;
101
Antoine Pitrou902fc8b2013-02-10 00:02:44 +0100102#ifdef SQLITE_OPEN_URI
103 Py_BEGIN_ALLOW_THREADS
104 rc = sqlite3_open_v2(database, &self->db,
105 SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE |
106 (uri ? SQLITE_OPEN_URI : 0), NULL);
107#else
108 if (uri) {
109 PyErr_SetString(pysqlite_NotSupportedError, "URIs not supported");
110 return -1;
111 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000112 Py_BEGIN_ALLOW_THREADS
113 rc = sqlite3_open(database, &self->db);
Antoine Pitrou902fc8b2013-02-10 00:02:44 +0100114#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000115 Py_END_ALLOW_THREADS
116
117 if (rc != SQLITE_OK) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000118 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000119 return -1;
120 }
121
122 if (!isolation_level) {
Neal Norwitzefee9f52007-10-27 02:50:52 +0000123 isolation_level = PyUnicode_FromString("");
Thomas Wouters477c8d52006-05-27 19:21:47 +0000124 if (!isolation_level) {
125 return -1;
126 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000127 } else {
128 Py_INCREF(isolation_level);
129 }
130 self->isolation_level = NULL;
Victor Stinnercb1f74e2013-12-19 16:38:03 +0100131 if (pysqlite_connection_set_isolation_level(self, isolation_level) < 0) {
132 Py_DECREF(isolation_level);
133 return -1;
134 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000135 Py_DECREF(isolation_level);
136
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000137 self->statement_cache = (pysqlite_Cache*)PyObject_CallFunction((PyObject*)&pysqlite_CacheType, "Oi", self, cached_statements);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000138 if (PyErr_Occurred()) {
139 return -1;
140 }
141
Gerhard Häringf9cee222010-03-05 15:20:03 +0000142 self->created_statements = 0;
143 self->created_cursors = 0;
144
145 /* Create lists of weak references to statements/cursors */
Thomas Wouters477c8d52006-05-27 19:21:47 +0000146 self->statements = PyList_New(0);
Gerhard Häringf9cee222010-03-05 15:20:03 +0000147 self->cursors = PyList_New(0);
148 if (!self->statements || !self->cursors) {
Thomas Wouters477c8d52006-05-27 19:21:47 +0000149 return -1;
150 }
Thomas Wouters477c8d52006-05-27 19:21:47 +0000151
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000152 /* By default, the Cache class INCREFs the factory in its initializer, and
153 * decrefs it in its deallocator method. Since this would create a circular
154 * reference here, we're breaking it by decrementing self, and telling the
155 * cache class to not decref the factory (self) in its deallocator.
156 */
157 self->statement_cache->decref_factory = 0;
158 Py_DECREF(self);
159
160 self->inTransaction = 0;
161 self->detect_types = detect_types;
162 self->timeout = timeout;
163 (void)sqlite3_busy_timeout(self->db, (int)(timeout*1000));
Georg Brandldfd73442009-04-05 11:47:34 +0000164#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000165 self->thread_ident = PyThread_get_thread_ident();
Georg Brandldfd73442009-04-05 11:47:34 +0000166#endif
Berker Peksag7bea2342016-06-12 14:09:51 +0300167 if (!check_same_thread && sqlite3_libversion_number() < 3003001) {
168 PyErr_SetString(pysqlite_NotSupportedError, "shared connections not available");
169 return -1;
170 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000171 self->check_same_thread = check_same_thread;
172
173 self->function_pinboard = PyDict_New();
174 if (!self->function_pinboard) {
175 return -1;
176 }
177
178 self->collations = PyDict_New();
179 if (!self->collations) {
180 return -1;
181 }
182
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000183 self->Warning = pysqlite_Warning;
184 self->Error = pysqlite_Error;
185 self->InterfaceError = pysqlite_InterfaceError;
186 self->DatabaseError = pysqlite_DatabaseError;
187 self->DataError = pysqlite_DataError;
188 self->OperationalError = pysqlite_OperationalError;
189 self->IntegrityError = pysqlite_IntegrityError;
190 self->InternalError = pysqlite_InternalError;
191 self->ProgrammingError = pysqlite_ProgrammingError;
192 self->NotSupportedError = pysqlite_NotSupportedError;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000193
194 return 0;
195}
196
Thomas Wouters477c8d52006-05-27 19:21:47 +0000197/* Empty the entire statement cache of this connection */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000198void pysqlite_flush_statement_cache(pysqlite_Connection* self)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000199{
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000200 pysqlite_Node* node;
201 pysqlite_Statement* statement;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000202
203 node = self->statement_cache->first;
204
205 while (node) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000206 statement = (pysqlite_Statement*)(node->data);
207 (void)pysqlite_statement_finalize(statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000208 node = node->next;
209 }
210
Serhiy Storchaka57a01d32016-04-10 18:05:40 +0300211 Py_SETREF(self->statement_cache,
Serhiy Storchaka5a57ade2015-12-24 10:35:59 +0200212 (pysqlite_Cache *)PyObject_CallFunction((PyObject *)&pysqlite_CacheType, "O", self));
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000213 Py_DECREF(self);
214 self->statement_cache->decref_factory = 0;
215}
216
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000217/* action in (ACTION_RESET, ACTION_FINALIZE) */
Gerhard Häringf9cee222010-03-05 15:20:03 +0000218void pysqlite_do_all_statements(pysqlite_Connection* self, int action, int reset_cursors)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000219{
Thomas Wouters477c8d52006-05-27 19:21:47 +0000220 int i;
221 PyObject* weakref;
222 PyObject* statement;
Gerhard Häringf9cee222010-03-05 15:20:03 +0000223 pysqlite_Cursor* cursor;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000224
Thomas Wouters477c8d52006-05-27 19:21:47 +0000225 for (i = 0; i < PyList_Size(self->statements); i++) {
226 weakref = PyList_GetItem(self->statements, i);
227 statement = PyWeakref_GetObject(weakref);
228 if (statement != Py_None) {
Benjamin Peterson5c2b09e2011-05-31 21:31:37 -0500229 Py_INCREF(statement);
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000230 if (action == ACTION_RESET) {
231 (void)pysqlite_statement_reset((pysqlite_Statement*)statement);
232 } else {
233 (void)pysqlite_statement_finalize((pysqlite_Statement*)statement);
234 }
Benjamin Peterson5c2b09e2011-05-31 21:31:37 -0500235 Py_DECREF(statement);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000236 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000237 }
Gerhard Häringf9cee222010-03-05 15:20:03 +0000238
239 if (reset_cursors) {
240 for (i = 0; i < PyList_Size(self->cursors); i++) {
241 weakref = PyList_GetItem(self->cursors, i);
242 cursor = (pysqlite_Cursor*)PyWeakref_GetObject(weakref);
243 if ((PyObject*)cursor != Py_None) {
244 cursor->reset = 1;
245 }
246 }
247 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000248}
249
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000250void pysqlite_connection_dealloc(pysqlite_Connection* self)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000251{
252 Py_XDECREF(self->statement_cache);
253
254 /* Clean up if user has not called .close() explicitly. */
255 if (self->db) {
256 Py_BEGIN_ALLOW_THREADS
257 sqlite3_close(self->db);
258 Py_END_ALLOW_THREADS
259 }
260
261 if (self->begin_statement) {
262 PyMem_Free(self->begin_statement);
263 }
264 Py_XDECREF(self->isolation_level);
265 Py_XDECREF(self->function_pinboard);
266 Py_XDECREF(self->row_factory);
267 Py_XDECREF(self->text_factory);
268 Py_XDECREF(self->collations);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000269 Py_XDECREF(self->statements);
Gerhard Häringf9cee222010-03-05 15:20:03 +0000270 Py_XDECREF(self->cursors);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000271
Christian Heimes90aa7642007-12-19 02:45:37 +0000272 Py_TYPE(self)->tp_free((PyObject*)self);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000273}
274
Gerhard Häringf9cee222010-03-05 15:20:03 +0000275/*
276 * Registers a cursor with the connection.
277 *
278 * 0 => error; 1 => ok
279 */
280int pysqlite_connection_register_cursor(pysqlite_Connection* connection, PyObject* cursor)
281{
282 PyObject* weakref;
283
284 weakref = PyWeakref_NewRef((PyObject*)cursor, NULL);
285 if (!weakref) {
286 goto error;
287 }
288
289 if (PyList_Append(connection->cursors, weakref) != 0) {
290 Py_CLEAR(weakref);
291 goto error;
292 }
293
294 Py_DECREF(weakref);
295
296 return 1;
297error:
298 return 0;
299}
300
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000301PyObject* pysqlite_connection_cursor(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000302{
303 static char *kwlist[] = {"factory", NULL, NULL};
304 PyObject* factory = NULL;
305 PyObject* cursor;
306
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000307 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "|O", kwlist,
308 &factory)) {
309 return NULL;
310 }
311
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000312 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000313 return NULL;
314 }
315
316 if (factory == NULL) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000317 factory = (PyObject*)&pysqlite_CursorType;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000318 }
319
320 cursor = PyObject_CallFunction(factory, "O", self);
321
Gerhard Häringf9cee222010-03-05 15:20:03 +0000322 _pysqlite_drop_unused_cursor_references(self);
323
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000324 if (cursor && self->row_factory != Py_None) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000325 Py_INCREF(self->row_factory);
Serhiy Storchaka48842712016-04-06 09:45:48 +0300326 Py_XSETREF(((pysqlite_Cursor *)cursor)->row_factory, self->row_factory);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000327 }
328
329 return cursor;
330}
331
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000332PyObject* pysqlite_connection_close(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000333{
334 int rc;
335
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000336 if (!pysqlite_check_thread(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000337 return NULL;
338 }
339
Gerhard Häringf9cee222010-03-05 15:20:03 +0000340 pysqlite_do_all_statements(self, ACTION_FINALIZE, 1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000341
342 if (self->db) {
343 Py_BEGIN_ALLOW_THREADS
344 rc = sqlite3_close(self->db);
345 Py_END_ALLOW_THREADS
346
347 if (rc != SQLITE_OK) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000348 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000349 return NULL;
350 } else {
351 self->db = NULL;
352 }
353 }
354
Berker Peksagfe21de92016-04-09 07:34:39 +0300355 Py_RETURN_NONE;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000356}
357
358/*
359 * Checks if a connection object is usable (i. e. not closed).
360 *
361 * 0 => error; 1 => ok
362 */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000363int pysqlite_check_connection(pysqlite_Connection* con)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000364{
Gerhard Häringf9cee222010-03-05 15:20:03 +0000365 if (!con->initialized) {
366 PyErr_SetString(pysqlite_ProgrammingError, "Base Connection.__init__ not called.");
367 return 0;
368 }
369
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000370 if (!con->db) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000371 PyErr_SetString(pysqlite_ProgrammingError, "Cannot operate on a closed database.");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000372 return 0;
373 } else {
374 return 1;
375 }
376}
377
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000378PyObject* _pysqlite_connection_begin(pysqlite_Connection* self)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000379{
380 int rc;
381 const char* tail;
382 sqlite3_stmt* statement;
383
384 Py_BEGIN_ALLOW_THREADS
385 rc = sqlite3_prepare(self->db, self->begin_statement, -1, &statement, &tail);
386 Py_END_ALLOW_THREADS
387
388 if (rc != SQLITE_OK) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000389 _pysqlite_seterror(self->db, statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000390 goto error;
391 }
392
Benjamin Petersond7b03282008-09-13 15:58:53 +0000393 rc = pysqlite_step(statement, self);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000394 if (rc == SQLITE_DONE) {
395 self->inTransaction = 1;
396 } else {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000397 _pysqlite_seterror(self->db, statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000398 }
399
400 Py_BEGIN_ALLOW_THREADS
401 rc = sqlite3_finalize(statement);
402 Py_END_ALLOW_THREADS
403
404 if (rc != SQLITE_OK && !PyErr_Occurred()) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000405 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000406 }
407
408error:
409 if (PyErr_Occurred()) {
410 return NULL;
411 } else {
412 Py_INCREF(Py_None);
413 return Py_None;
414 }
415}
416
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000417PyObject* pysqlite_connection_commit(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000418{
419 int rc;
420 const char* tail;
421 sqlite3_stmt* statement;
422
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000423 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000424 return NULL;
425 }
426
427 if (self->inTransaction) {
Gerhard Häringf9cee222010-03-05 15:20:03 +0000428
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000429 Py_BEGIN_ALLOW_THREADS
430 rc = sqlite3_prepare(self->db, "COMMIT", -1, &statement, &tail);
431 Py_END_ALLOW_THREADS
432 if (rc != SQLITE_OK) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000433 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000434 goto error;
435 }
436
Benjamin Petersond7b03282008-09-13 15:58:53 +0000437 rc = pysqlite_step(statement, self);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000438 if (rc == SQLITE_DONE) {
439 self->inTransaction = 0;
440 } else {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000441 _pysqlite_seterror(self->db, statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000442 }
443
444 Py_BEGIN_ALLOW_THREADS
445 rc = sqlite3_finalize(statement);
446 Py_END_ALLOW_THREADS
447 if (rc != SQLITE_OK && !PyErr_Occurred()) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000448 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000449 }
450
451 }
452
453error:
454 if (PyErr_Occurred()) {
455 return NULL;
456 } else {
457 Py_INCREF(Py_None);
458 return Py_None;
459 }
460}
461
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000462PyObject* pysqlite_connection_rollback(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000463{
464 int rc;
465 const char* tail;
466 sqlite3_stmt* statement;
467
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000468 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000469 return NULL;
470 }
471
472 if (self->inTransaction) {
Gerhard Häringf9cee222010-03-05 15:20:03 +0000473 pysqlite_do_all_statements(self, ACTION_RESET, 1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000474
475 Py_BEGIN_ALLOW_THREADS
Georg Brandl0eaa9402007-08-11 15:39:18 +0000476 rc = sqlite3_prepare(self->db, "ROLLBACK", -1, &statement, &tail);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000477 Py_END_ALLOW_THREADS
478 if (rc != SQLITE_OK) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000479 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000480 goto error;
481 }
482
Benjamin Petersond7b03282008-09-13 15:58:53 +0000483 rc = pysqlite_step(statement, self);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000484 if (rc == SQLITE_DONE) {
485 self->inTransaction = 0;
486 } else {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000487 _pysqlite_seterror(self->db, statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000488 }
489
490 Py_BEGIN_ALLOW_THREADS
491 rc = sqlite3_finalize(statement);
492 Py_END_ALLOW_THREADS
493 if (rc != SQLITE_OK && !PyErr_Occurred()) {
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000494 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000495 }
496
497 }
498
499error:
500 if (PyErr_Occurred()) {
501 return NULL;
502 } else {
503 Py_INCREF(Py_None);
504 return Py_None;
505 }
506}
507
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200508static int
509_pysqlite_set_result(sqlite3_context* context, PyObject* py_val)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000510{
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200511 if (py_val == Py_None) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000512 sqlite3_result_null(context);
Christian Heimes217cfd12007-12-02 14:31:20 +0000513 } else if (PyLong_Check(py_val)) {
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200514 sqlite_int64 value = _pysqlite_long_as_int64(py_val);
515 if (value == -1 && PyErr_Occurred())
516 return -1;
517 sqlite3_result_int64(context, value);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000518 } else if (PyFloat_Check(py_val)) {
519 sqlite3_result_double(context, PyFloat_AsDouble(py_val));
Guido van Rossumbae07c92007-10-08 02:46:15 +0000520 } else if (PyUnicode_Check(py_val)) {
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200521 const char *str = _PyUnicode_AsString(py_val);
522 if (str == NULL)
523 return -1;
524 sqlite3_result_text(context, str, -1, SQLITE_TRANSIENT);
Guido van Rossumbae07c92007-10-08 02:46:15 +0000525 } else if (PyObject_CheckBuffer(py_val)) {
Serhiy Storchaka4fdb6842015-02-03 01:21:08 +0200526 Py_buffer view;
527 if (PyObject_GetBuffer(py_val, &view, PyBUF_SIMPLE) != 0) {
Victor Stinner83ed42b2013-11-18 01:24:31 +0100528 PyErr_SetString(PyExc_ValueError,
529 "could not convert BLOB to buffer");
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200530 return -1;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000531 }
Serhiy Storchaka4fdb6842015-02-03 01:21:08 +0200532 if (view.len > INT_MAX) {
Victor Stinner83ed42b2013-11-18 01:24:31 +0100533 PyErr_SetString(PyExc_OverflowError,
534 "BLOB longer than INT_MAX bytes");
Serhiy Storchaka4fdb6842015-02-03 01:21:08 +0200535 PyBuffer_Release(&view);
Victor Stinner83ed42b2013-11-18 01:24:31 +0100536 return -1;
537 }
Serhiy Storchaka4fdb6842015-02-03 01:21:08 +0200538 sqlite3_result_blob(context, view.buf, (int)view.len, SQLITE_TRANSIENT);
539 PyBuffer_Release(&view);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000540 } else {
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200541 return -1;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000542 }
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200543 return 0;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000544}
545
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000546PyObject* _pysqlite_build_py_params(sqlite3_context *context, int argc, sqlite3_value** argv)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000547{
548 PyObject* args;
549 int i;
550 sqlite3_value* cur_value;
551 PyObject* cur_py_value;
552 const char* val_str;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000553 Py_ssize_t buflen;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000554
555 args = PyTuple_New(argc);
556 if (!args) {
557 return NULL;
558 }
559
560 for (i = 0; i < argc; i++) {
561 cur_value = argv[i];
562 switch (sqlite3_value_type(argv[i])) {
563 case SQLITE_INTEGER:
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200564 cur_py_value = _pysqlite_long_from_int64(sqlite3_value_int64(cur_value));
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000565 break;
566 case SQLITE_FLOAT:
567 cur_py_value = PyFloat_FromDouble(sqlite3_value_double(cur_value));
568 break;
569 case SQLITE_TEXT:
570 val_str = (const char*)sqlite3_value_text(cur_value);
Guido van Rossum98297ee2007-11-06 21:34:58 +0000571 cur_py_value = PyUnicode_FromString(val_str);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000572 /* TODO: have a way to show errors here */
573 if (!cur_py_value) {
Thomas Wouters477c8d52006-05-27 19:21:47 +0000574 PyErr_Clear();
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000575 Py_INCREF(Py_None);
576 cur_py_value = Py_None;
577 }
578 break;
579 case SQLITE_BLOB:
580 buflen = sqlite3_value_bytes(cur_value);
Christian Heimes72b710a2008-05-26 13:28:38 +0000581 cur_py_value = PyBytes_FromStringAndSize(
Guido van Rossumbae07c92007-10-08 02:46:15 +0000582 sqlite3_value_blob(cur_value), buflen);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000583 break;
584 case SQLITE_NULL:
585 default:
586 Py_INCREF(Py_None);
587 cur_py_value = Py_None;
588 }
Thomas Wouters477c8d52006-05-27 19:21:47 +0000589
590 if (!cur_py_value) {
591 Py_DECREF(args);
592 return NULL;
593 }
594
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000595 PyTuple_SetItem(args, i, cur_py_value);
596
597 }
598
599 return args;
600}
601
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000602void _pysqlite_func_callback(sqlite3_context* context, int argc, sqlite3_value** argv)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000603{
604 PyObject* args;
605 PyObject* py_func;
Thomas Wouters477c8d52006-05-27 19:21:47 +0000606 PyObject* py_retval = NULL;
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200607 int ok;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000608
Georg Brandldfd73442009-04-05 11:47:34 +0000609#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000610 PyGILState_STATE threadstate;
611
612 threadstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +0000613#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000614
615 py_func = (PyObject*)sqlite3_user_data(context);
616
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000617 args = _pysqlite_build_py_params(context, argc, argv);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000618 if (args) {
619 py_retval = PyObject_CallObject(py_func, args);
620 Py_DECREF(args);
621 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000622
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200623 ok = 0;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000624 if (py_retval) {
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200625 ok = _pysqlite_set_result(context, py_retval) == 0;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000626 Py_DECREF(py_retval);
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200627 }
628 if (!ok) {
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000629 if (_enable_callback_tracebacks) {
630 PyErr_Print();
631 } else {
632 PyErr_Clear();
633 }
634 _sqlite3_result_error(context, "user-defined function raised exception", -1);
635 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000636
Georg Brandldfd73442009-04-05 11:47:34 +0000637#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000638 PyGILState_Release(threadstate);
Georg Brandldfd73442009-04-05 11:47:34 +0000639#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000640}
641
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000642static void _pysqlite_step_callback(sqlite3_context *context, int argc, sqlite3_value** params)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000643{
644 PyObject* args;
Thomas Wouters477c8d52006-05-27 19:21:47 +0000645 PyObject* function_result = NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000646 PyObject* aggregate_class;
647 PyObject** aggregate_instance;
Thomas Wouters477c8d52006-05-27 19:21:47 +0000648 PyObject* stepmethod = NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000649
Georg Brandldfd73442009-04-05 11:47:34 +0000650#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000651 PyGILState_STATE threadstate;
652
653 threadstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +0000654#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000655
656 aggregate_class = (PyObject*)sqlite3_user_data(context);
657
658 aggregate_instance = (PyObject**)sqlite3_aggregate_context(context, sizeof(PyObject*));
659
660 if (*aggregate_instance == 0) {
661 *aggregate_instance = PyObject_CallFunction(aggregate_class, "");
662
Thomas Wouters477c8d52006-05-27 19:21:47 +0000663 if (PyErr_Occurred()) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000664 *aggregate_instance = 0;
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000665 if (_enable_callback_tracebacks) {
666 PyErr_Print();
667 } else {
668 PyErr_Clear();
669 }
670 _sqlite3_result_error(context, "user-defined aggregate's '__init__' method raised error", -1);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000671 goto error;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000672 }
673 }
674
675 stepmethod = PyObject_GetAttrString(*aggregate_instance, "step");
Thomas Wouters477c8d52006-05-27 19:21:47 +0000676 if (!stepmethod) {
677 goto error;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000678 }
679
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000680 args = _pysqlite_build_py_params(context, argc, params);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000681 if (!args) {
682 goto error;
683 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000684
685 function_result = PyObject_CallObject(stepmethod, args);
686 Py_DECREF(args);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000687
Thomas Wouters477c8d52006-05-27 19:21:47 +0000688 if (!function_result) {
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000689 if (_enable_callback_tracebacks) {
690 PyErr_Print();
691 } else {
692 PyErr_Clear();
693 }
694 _sqlite3_result_error(context, "user-defined aggregate's 'step' method raised error", -1);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000695 }
696
Thomas Wouters477c8d52006-05-27 19:21:47 +0000697error:
698 Py_XDECREF(stepmethod);
699 Py_XDECREF(function_result);
700
Georg Brandldfd73442009-04-05 11:47:34 +0000701#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000702 PyGILState_Release(threadstate);
Georg Brandldfd73442009-04-05 11:47:34 +0000703#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000704}
705
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000706void _pysqlite_final_callback(sqlite3_context* context)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000707{
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200708 PyObject* function_result;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000709 PyObject** aggregate_instance;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +0200710 _Py_IDENTIFIER(finalize);
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200711 int ok;
Victor Stinnere9af4cf2013-07-18 01:42:04 +0200712 PyObject *exception, *value, *tb;
Victor Stinnerffff7632013-08-02 01:48:10 +0200713 int restore;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000714
Georg Brandldfd73442009-04-05 11:47:34 +0000715#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000716 PyGILState_STATE threadstate;
717
718 threadstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +0000719#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000720
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000721 aggregate_instance = (PyObject**)sqlite3_aggregate_context(context, sizeof(PyObject*));
722 if (!*aggregate_instance) {
723 /* this branch is executed if there was an exception in the aggregate's
724 * __init__ */
725
Thomas Wouters477c8d52006-05-27 19:21:47 +0000726 goto error;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000727 }
728
Victor Stinnere9af4cf2013-07-18 01:42:04 +0200729 /* Keep the exception (if any) of the last call to step() */
730 PyErr_Fetch(&exception, &value, &tb);
Victor Stinnerffff7632013-08-02 01:48:10 +0200731 restore = 1;
Victor Stinnere9af4cf2013-07-18 01:42:04 +0200732
Martin v. Löwisafe55bb2011-10-09 10:38:36 +0200733 function_result = _PyObject_CallMethodId(*aggregate_instance, &PyId_finalize, "");
Victor Stinnere9af4cf2013-07-18 01:42:04 +0200734
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +0200735 Py_DECREF(*aggregate_instance);
736
737 ok = 0;
738 if (function_result) {
739 ok = _pysqlite_set_result(context, function_result) == 0;
740 Py_DECREF(function_result);
741 }
742 if (!ok) {
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000743 if (_enable_callback_tracebacks) {
744 PyErr_Print();
745 } else {
746 PyErr_Clear();
747 }
748 _sqlite3_result_error(context, "user-defined aggregate's 'finalize' method raised error", -1);
Victor Stinnerffff7632013-08-02 01:48:10 +0200749#if SQLITE_VERSION_NUMBER < 3003003
750 /* with old SQLite versions, _sqlite3_result_error() sets a new Python
751 exception, so don't restore the previous exception */
752 restore = 0;
753#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000754 }
755
Victor Stinnerffff7632013-08-02 01:48:10 +0200756 if (restore) {
757 /* Restore the exception (if any) of the last call to step(),
758 but clear also the current exception if finalize() failed */
759 PyErr_Restore(exception, value, tb);
760 }
Victor Stinner3a857322013-07-22 08:34:32 +0200761
Thomas Wouters477c8d52006-05-27 19:21:47 +0000762error:
Georg Brandldfd73442009-04-05 11:47:34 +0000763#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000764 PyGILState_Release(threadstate);
Georg Brandldfd73442009-04-05 11:47:34 +0000765#endif
Victor Stinnerb84fc0f2013-08-28 01:44:42 +0200766 /* explicit return to avoid a compilation error if WITH_THREAD
767 is not defined */
768 return;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000769}
770
Gerhard Häringf9cee222010-03-05 15:20:03 +0000771static void _pysqlite_drop_unused_statement_references(pysqlite_Connection* self)
Thomas Wouters477c8d52006-05-27 19:21:47 +0000772{
773 PyObject* new_list;
774 PyObject* weakref;
775 int i;
776
777 /* we only need to do this once in a while */
778 if (self->created_statements++ < 200) {
779 return;
780 }
781
782 self->created_statements = 0;
783
784 new_list = PyList_New(0);
785 if (!new_list) {
786 return;
787 }
788
789 for (i = 0; i < PyList_Size(self->statements); i++) {
790 weakref = PyList_GetItem(self->statements, i);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000791 if (PyWeakref_GetObject(weakref) != Py_None) {
Thomas Wouters477c8d52006-05-27 19:21:47 +0000792 if (PyList_Append(new_list, weakref) != 0) {
793 Py_DECREF(new_list);
794 return;
795 }
796 }
797 }
798
Serhiy Storchaka57a01d32016-04-10 18:05:40 +0300799 Py_SETREF(self->statements, new_list);
Thomas Wouters477c8d52006-05-27 19:21:47 +0000800}
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000801
Gerhard Häringf9cee222010-03-05 15:20:03 +0000802static void _pysqlite_drop_unused_cursor_references(pysqlite_Connection* self)
803{
804 PyObject* new_list;
805 PyObject* weakref;
806 int i;
807
808 /* we only need to do this once in a while */
809 if (self->created_cursors++ < 200) {
810 return;
811 }
812
813 self->created_cursors = 0;
814
815 new_list = PyList_New(0);
816 if (!new_list) {
817 return;
818 }
819
820 for (i = 0; i < PyList_Size(self->cursors); i++) {
821 weakref = PyList_GetItem(self->cursors, i);
822 if (PyWeakref_GetObject(weakref) != Py_None) {
823 if (PyList_Append(new_list, weakref) != 0) {
824 Py_DECREF(new_list);
825 return;
826 }
827 }
828 }
829
Serhiy Storchaka57a01d32016-04-10 18:05:40 +0300830 Py_SETREF(self->cursors, new_list);
Gerhard Häringf9cee222010-03-05 15:20:03 +0000831}
832
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000833PyObject* pysqlite_connection_create_function(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000834{
835 static char *kwlist[] = {"name", "narg", "func", NULL, NULL};
836
837 PyObject* func;
838 char* name;
839 int narg;
840 int rc;
841
Gerhard Häringf9cee222010-03-05 15:20:03 +0000842 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
843 return NULL;
844 }
845
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000846 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "siO", kwlist,
847 &name, &narg, &func))
848 {
849 return NULL;
850 }
851
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000852 rc = sqlite3_create_function(self->db, name, narg, SQLITE_UTF8, (void*)func, _pysqlite_func_callback, NULL, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000853
Thomas Wouters477c8d52006-05-27 19:21:47 +0000854 if (rc != SQLITE_OK) {
855 /* Workaround for SQLite bug: no error code or string is available here */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000856 PyErr_SetString(pysqlite_OperationalError, "Error creating function");
Thomas Wouters477c8d52006-05-27 19:21:47 +0000857 return NULL;
858 } else {
Gerhard Häringf9cee222010-03-05 15:20:03 +0000859 if (PyDict_SetItem(self->function_pinboard, func, Py_None) == -1)
860 return NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000861
Berker Peksagfe21de92016-04-09 07:34:39 +0300862 Py_RETURN_NONE;
Thomas Wouters477c8d52006-05-27 19:21:47 +0000863 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000864}
865
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000866PyObject* pysqlite_connection_create_aggregate(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000867{
868 PyObject* aggregate_class;
869
870 int n_arg;
871 char* name;
872 static char *kwlist[] = { "name", "n_arg", "aggregate_class", NULL };
873 int rc;
874
Gerhard Häringf9cee222010-03-05 15:20:03 +0000875 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
876 return NULL;
877 }
878
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000879 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "siO:create_aggregate",
880 kwlist, &name, &n_arg, &aggregate_class)) {
881 return NULL;
882 }
883
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000884 rc = sqlite3_create_function(self->db, name, n_arg, SQLITE_UTF8, (void*)aggregate_class, 0, &_pysqlite_step_callback, &_pysqlite_final_callback);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000885 if (rc != SQLITE_OK) {
Thomas Wouters477c8d52006-05-27 19:21:47 +0000886 /* Workaround for SQLite bug: no error code or string is available here */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000887 PyErr_SetString(pysqlite_OperationalError, "Error creating aggregate");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000888 return NULL;
889 } else {
Gerhard Häringf9cee222010-03-05 15:20:03 +0000890 if (PyDict_SetItem(self->function_pinboard, aggregate_class, Py_None) == -1)
891 return NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000892
Berker Peksagfe21de92016-04-09 07:34:39 +0300893 Py_RETURN_NONE;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000894 }
895}
896
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +0000897static int _authorizer_callback(void* user_arg, int action, const char* arg1, const char* arg2 , const char* dbname, const char* access_attempt_source)
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000898{
899 PyObject *ret;
900 int rc;
Georg Brandldfd73442009-04-05 11:47:34 +0000901#ifdef WITH_THREAD
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000902 PyGILState_STATE gilstate;
903
904 gilstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +0000905#endif
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000906
Victor Stinnerd4095d92013-07-26 22:23:33 +0200907 ret = PyObject_CallFunction((PyObject*)user_arg, "issss", action, arg1, arg2, dbname, access_attempt_source);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000908
Victor Stinnerd4095d92013-07-26 22:23:33 +0200909 if (ret == NULL) {
910 if (_enable_callback_tracebacks)
911 PyErr_Print();
912 else
913 PyErr_Clear();
Victor Stinner41801f52013-07-21 13:05:38 +0200914
Victor Stinnerd4095d92013-07-26 22:23:33 +0200915 rc = SQLITE_DENY;
Victor Stinner41801f52013-07-21 13:05:38 +0200916 }
917 else {
Victor Stinnerd4095d92013-07-26 22:23:33 +0200918 if (PyLong_Check(ret)) {
919 rc = _PyLong_AsInt(ret);
920 if (rc == -1 && PyErr_Occurred()) {
921 if (_enable_callback_tracebacks)
922 PyErr_Print();
923 else
924 PyErr_Clear();
925 rc = SQLITE_DENY;
926 }
927 }
928 else {
929 rc = SQLITE_DENY;
930 }
931 Py_DECREF(ret);
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000932 }
933
Georg Brandldfd73442009-04-05 11:47:34 +0000934#ifdef WITH_THREAD
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000935 PyGILState_Release(gilstate);
Georg Brandldfd73442009-04-05 11:47:34 +0000936#endif
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000937 return rc;
938}
939
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000940static int _progress_handler(void* user_arg)
941{
942 int rc;
943 PyObject *ret;
Georg Brandldfd73442009-04-05 11:47:34 +0000944#ifdef WITH_THREAD
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000945 PyGILState_STATE gilstate;
946
947 gilstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +0000948#endif
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000949 ret = PyObject_CallFunction((PyObject*)user_arg, "");
950
951 if (!ret) {
952 if (_enable_callback_tracebacks) {
953 PyErr_Print();
954 } else {
955 PyErr_Clear();
956 }
957
Mark Dickinson934896d2009-02-21 20:59:32 +0000958 /* abort query if error occurred */
Victor Stinner86999502010-05-19 01:27:23 +0000959 rc = 1;
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000960 } else {
961 rc = (int)PyObject_IsTrue(ret);
962 Py_DECREF(ret);
963 }
964
Georg Brandldfd73442009-04-05 11:47:34 +0000965#ifdef WITH_THREAD
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000966 PyGILState_Release(gilstate);
Georg Brandldfd73442009-04-05 11:47:34 +0000967#endif
Gerhard Häringe7ea7452008-03-29 00:45:29 +0000968 return rc;
969}
970
Antoine Pitrou5bfa0622011-04-04 00:12:04 +0200971static void _trace_callback(void* user_arg, const char* statement_string)
972{
973 PyObject *py_statement = NULL;
974 PyObject *ret = NULL;
975
976#ifdef WITH_THREAD
977 PyGILState_STATE gilstate;
978
979 gilstate = PyGILState_Ensure();
980#endif
981 py_statement = PyUnicode_DecodeUTF8(statement_string,
982 strlen(statement_string), "replace");
983 if (py_statement) {
984 ret = PyObject_CallFunctionObjArgs((PyObject*)user_arg, py_statement, NULL);
985 Py_DECREF(py_statement);
986 }
987
988 if (ret) {
989 Py_DECREF(ret);
990 } else {
991 if (_enable_callback_tracebacks) {
992 PyErr_Print();
993 } else {
994 PyErr_Clear();
995 }
996 }
997
998#ifdef WITH_THREAD
999 PyGILState_Release(gilstate);
1000#endif
1001}
1002
Gerhard Häringf9cee222010-03-05 15:20:03 +00001003static PyObject* pysqlite_connection_set_authorizer(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001004{
1005 PyObject* authorizer_cb;
1006
1007 static char *kwlist[] = { "authorizer_callback", NULL };
1008 int rc;
1009
Gerhard Häringf9cee222010-03-05 15:20:03 +00001010 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1011 return NULL;
1012 }
1013
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001014 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O:set_authorizer",
1015 kwlist, &authorizer_cb)) {
1016 return NULL;
1017 }
1018
1019 rc = sqlite3_set_authorizer(self->db, _authorizer_callback, (void*)authorizer_cb);
1020
1021 if (rc != SQLITE_OK) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001022 PyErr_SetString(pysqlite_OperationalError, "Error setting authorizer callback");
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001023 return NULL;
1024 } else {
Gerhard Häringf9cee222010-03-05 15:20:03 +00001025 if (PyDict_SetItem(self->function_pinboard, authorizer_cb, Py_None) == -1)
1026 return NULL;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001027
Berker Peksagfe21de92016-04-09 07:34:39 +03001028 Py_RETURN_NONE;
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001029 }
1030}
1031
Gerhard Häringf9cee222010-03-05 15:20:03 +00001032static PyObject* pysqlite_connection_set_progress_handler(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001033{
1034 PyObject* progress_handler;
1035 int n;
1036
1037 static char *kwlist[] = { "progress_handler", "n", NULL };
1038
Gerhard Häringf9cee222010-03-05 15:20:03 +00001039 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1040 return NULL;
1041 }
1042
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001043 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "Oi:set_progress_handler",
1044 kwlist, &progress_handler, &n)) {
1045 return NULL;
1046 }
1047
1048 if (progress_handler == Py_None) {
1049 /* None clears the progress handler previously set */
1050 sqlite3_progress_handler(self->db, 0, 0, (void*)0);
1051 } else {
1052 sqlite3_progress_handler(self->db, n, _progress_handler, progress_handler);
Gerhard Häringf9cee222010-03-05 15:20:03 +00001053 if (PyDict_SetItem(self->function_pinboard, progress_handler, Py_None) == -1)
1054 return NULL;
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001055 }
1056
Berker Peksagfe21de92016-04-09 07:34:39 +03001057 Py_RETURN_NONE;
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001058}
1059
Antoine Pitrou5bfa0622011-04-04 00:12:04 +02001060static PyObject* pysqlite_connection_set_trace_callback(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
1061{
1062 PyObject* trace_callback;
1063
1064 static char *kwlist[] = { "trace_callback", NULL };
1065
1066 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1067 return NULL;
1068 }
1069
1070 if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O:set_trace_callback",
1071 kwlist, &trace_callback)) {
1072 return NULL;
1073 }
1074
1075 if (trace_callback == Py_None) {
1076 /* None clears the trace callback previously set */
1077 sqlite3_trace(self->db, 0, (void*)0);
1078 } else {
1079 if (PyDict_SetItem(self->function_pinboard, trace_callback, Py_None) == -1)
1080 return NULL;
1081 sqlite3_trace(self->db, _trace_callback, trace_callback);
1082 }
1083
Berker Peksagfe21de92016-04-09 07:34:39 +03001084 Py_RETURN_NONE;
Antoine Pitrou5bfa0622011-04-04 00:12:04 +02001085}
1086
Gerhard Häringf9cee222010-03-05 15:20:03 +00001087#ifdef HAVE_LOAD_EXTENSION
1088static PyObject* pysqlite_enable_load_extension(pysqlite_Connection* self, PyObject* args)
1089{
1090 int rc;
1091 int onoff;
1092
1093 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1094 return NULL;
1095 }
1096
1097 if (!PyArg_ParseTuple(args, "i", &onoff)) {
1098 return NULL;
1099 }
1100
1101 rc = sqlite3_enable_load_extension(self->db, onoff);
1102
1103 if (rc != SQLITE_OK) {
1104 PyErr_SetString(pysqlite_OperationalError, "Error enabling load extension");
1105 return NULL;
1106 } else {
Berker Peksagfe21de92016-04-09 07:34:39 +03001107 Py_RETURN_NONE;
Gerhard Häringf9cee222010-03-05 15:20:03 +00001108 }
1109}
1110
1111static PyObject* pysqlite_load_extension(pysqlite_Connection* self, PyObject* args)
1112{
1113 int rc;
1114 char* extension_name;
1115 char* errmsg;
1116
1117 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1118 return NULL;
1119 }
1120
1121 if (!PyArg_ParseTuple(args, "s", &extension_name)) {
1122 return NULL;
1123 }
1124
1125 rc = sqlite3_load_extension(self->db, extension_name, 0, &errmsg);
1126 if (rc != 0) {
1127 PyErr_SetString(pysqlite_OperationalError, errmsg);
1128 return NULL;
1129 } else {
Berker Peksagfe21de92016-04-09 07:34:39 +03001130 Py_RETURN_NONE;
Gerhard Häringf9cee222010-03-05 15:20:03 +00001131 }
1132}
1133#endif
1134
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001135int pysqlite_check_thread(pysqlite_Connection* self)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001136{
Georg Brandldfd73442009-04-05 11:47:34 +00001137#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001138 if (self->check_same_thread) {
1139 if (PyThread_get_thread_ident() != self->thread_ident) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001140 PyErr_Format(pysqlite_ProgrammingError,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001141 "SQLite objects created in a thread can only be used in that same thread."
1142 "The object was created in thread id %ld and this is thread id %ld",
1143 self->thread_ident, PyThread_get_thread_ident());
1144 return 0;
1145 }
1146
1147 }
Georg Brandldfd73442009-04-05 11:47:34 +00001148#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001149 return 1;
1150}
1151
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001152static PyObject* pysqlite_connection_get_isolation_level(pysqlite_Connection* self, void* unused)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001153{
1154 Py_INCREF(self->isolation_level);
1155 return self->isolation_level;
1156}
1157
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001158static PyObject* pysqlite_connection_get_total_changes(pysqlite_Connection* self, void* unused)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001159{
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001160 if (!pysqlite_check_connection(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001161 return NULL;
1162 } else {
1163 return Py_BuildValue("i", sqlite3_total_changes(self->db));
1164 }
1165}
1166
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001167static int pysqlite_connection_set_isolation_level(pysqlite_Connection* self, PyObject* isolation_level)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001168{
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001169 PyObject* res;
1170 PyObject* begin_statement;
Georg Brandlceab6102007-11-25 00:45:05 +00001171 static PyObject* begin_word;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001172
1173 Py_XDECREF(self->isolation_level);
1174
1175 if (self->begin_statement) {
1176 PyMem_Free(self->begin_statement);
1177 self->begin_statement = NULL;
1178 }
1179
1180 if (isolation_level == Py_None) {
1181 Py_INCREF(Py_None);
1182 self->isolation_level = Py_None;
1183
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001184 res = pysqlite_connection_commit(self, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001185 if (!res) {
1186 return -1;
1187 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001188 Py_DECREF(res);
1189
1190 self->inTransaction = 0;
1191 } else {
Neal Norwitzefee9f52007-10-27 02:50:52 +00001192 const char *statement;
1193 Py_ssize_t size;
1194
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001195 Py_INCREF(isolation_level);
1196 self->isolation_level = isolation_level;
1197
Georg Brandlceab6102007-11-25 00:45:05 +00001198 if (!begin_word) {
1199 begin_word = PyUnicode_FromString("BEGIN ");
1200 if (!begin_word) return -1;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001201 }
Georg Brandlceab6102007-11-25 00:45:05 +00001202 begin_statement = PyUnicode_Concat(begin_word, isolation_level);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001203 if (!begin_statement) {
1204 return -1;
1205 }
1206
Marc-André Lemburg4cc0f242008-08-07 18:54:33 +00001207 statement = _PyUnicode_AsStringAndSize(begin_statement, &size);
Georg Brandl3dbca812008-07-23 16:10:53 +00001208 if (!statement) {
Victor Stinnerff27d6b2010-03-13 00:57:22 +00001209 Py_DECREF(begin_statement);
Georg Brandl3dbca812008-07-23 16:10:53 +00001210 return -1;
1211 }
Neal Norwitzefee9f52007-10-27 02:50:52 +00001212 self->begin_statement = PyMem_Malloc(size + 2);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001213 if (!self->begin_statement) {
Georg Brandl3dbca812008-07-23 16:10:53 +00001214 Py_DECREF(begin_statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001215 return -1;
1216 }
1217
Neal Norwitzefee9f52007-10-27 02:50:52 +00001218 strcpy(self->begin_statement, statement);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001219 Py_DECREF(begin_statement);
1220 }
1221
1222 return 0;
1223}
1224
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001225PyObject* pysqlite_connection_call(pysqlite_Connection* self, PyObject* args, PyObject* kwargs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001226{
1227 PyObject* sql;
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001228 pysqlite_Statement* statement;
Thomas Wouters477c8d52006-05-27 19:21:47 +00001229 PyObject* weakref;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001230 int rc;
1231
Gerhard Häringf9cee222010-03-05 15:20:03 +00001232 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
1233 return NULL;
1234 }
1235
Larry Hastings3b12e952015-05-08 07:45:10 -07001236 if (!_PyArg_NoKeywords(MODULE_NAME ".Connection()", kwargs))
1237 return NULL;
1238
Victor Stinnerb3e1ef12013-11-05 14:46:13 +01001239 if (!PyArg_ParseTuple(args, "O", &sql))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001240 return NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001241
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001242 _pysqlite_drop_unused_statement_references(self);
Thomas Wouters477c8d52006-05-27 19:21:47 +00001243
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001244 statement = PyObject_New(pysqlite_Statement, &pysqlite_StatementType);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001245 if (!statement) {
1246 return NULL;
1247 }
1248
Victor Stinner0201f442010-03-13 03:28:34 +00001249 statement->db = NULL;
1250 statement->st = NULL;
1251 statement->sql = NULL;
1252 statement->in_use = 0;
1253 statement->in_weakreflist = NULL;
1254
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001255 rc = pysqlite_statement_create(statement, self, sql);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001256 if (rc != SQLITE_OK) {
1257 if (rc == PYSQLITE_TOO_MUCH_SQL) {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001258 PyErr_SetString(pysqlite_Warning, "You can only execute one statement at a time.");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001259 } else if (rc == PYSQLITE_SQL_WRONG_TYPE) {
Serhiy Storchaka42d67af2014-09-11 13:29:05 +03001260 if (PyErr_ExceptionMatches(PyExc_TypeError))
1261 PyErr_SetString(pysqlite_Warning, "SQL is of wrong type. Must be string.");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001262 } else {
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001263 (void)pysqlite_statement_reset(statement);
1264 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001265 }
Victor Stinnerb3e1ef12013-11-05 14:46:13 +01001266 goto error;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001267 }
1268
Victor Stinnerb3e1ef12013-11-05 14:46:13 +01001269 weakref = PyWeakref_NewRef((PyObject*)statement, NULL);
1270 if (weakref == NULL)
1271 goto error;
1272 if (PyList_Append(self->statements, weakref) != 0) {
1273 Py_DECREF(weakref);
1274 goto error;
1275 }
1276 Py_DECREF(weakref);
1277
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001278 return (PyObject*)statement;
Victor Stinnerb3e1ef12013-11-05 14:46:13 +01001279
1280error:
1281 Py_DECREF(statement);
1282 return NULL;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001283}
1284
Larry Hastings01b08832015-05-08 07:37:49 -07001285PyObject* pysqlite_connection_execute(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001286{
1287 PyObject* cursor = 0;
1288 PyObject* result = 0;
1289 PyObject* method = 0;
1290
Martin v. Löwisafe55bb2011-10-09 10:38:36 +02001291 cursor = _PyObject_CallMethodId((PyObject*)self, &PyId_cursor, "");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001292 if (!cursor) {
1293 goto error;
1294 }
1295
1296 method = PyObject_GetAttrString(cursor, "execute");
1297 if (!method) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001298 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001299 goto error;
1300 }
1301
1302 result = PyObject_CallObject(method, args);
1303 if (!result) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001304 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001305 }
1306
1307error:
1308 Py_XDECREF(result);
1309 Py_XDECREF(method);
1310
1311 return cursor;
1312}
1313
Larry Hastings01b08832015-05-08 07:37:49 -07001314PyObject* pysqlite_connection_executemany(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001315{
1316 PyObject* cursor = 0;
1317 PyObject* result = 0;
1318 PyObject* method = 0;
1319
Martin v. Löwisafe55bb2011-10-09 10:38:36 +02001320 cursor = _PyObject_CallMethodId((PyObject*)self, &PyId_cursor, "");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001321 if (!cursor) {
1322 goto error;
1323 }
1324
1325 method = PyObject_GetAttrString(cursor, "executemany");
1326 if (!method) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001327 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001328 goto error;
1329 }
1330
1331 result = PyObject_CallObject(method, args);
1332 if (!result) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001333 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001334 }
1335
1336error:
1337 Py_XDECREF(result);
1338 Py_XDECREF(method);
1339
1340 return cursor;
1341}
1342
Larry Hastings01b08832015-05-08 07:37:49 -07001343PyObject* pysqlite_connection_executescript(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001344{
1345 PyObject* cursor = 0;
1346 PyObject* result = 0;
1347 PyObject* method = 0;
1348
Martin v. Löwisafe55bb2011-10-09 10:38:36 +02001349 cursor = _PyObject_CallMethodId((PyObject*)self, &PyId_cursor, "");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001350 if (!cursor) {
1351 goto error;
1352 }
1353
1354 method = PyObject_GetAttrString(cursor, "executescript");
1355 if (!method) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001356 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001357 goto error;
1358 }
1359
1360 result = PyObject_CallObject(method, args);
1361 if (!result) {
Alexandre Vassalotti1839bac2008-07-13 21:57:48 +00001362 Py_CLEAR(cursor);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001363 }
1364
1365error:
1366 Py_XDECREF(result);
1367 Py_XDECREF(method);
1368
1369 return cursor;
1370}
1371
1372/* ------------------------- COLLATION CODE ------------------------ */
1373
1374static int
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001375pysqlite_collation_callback(
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001376 void* context,
1377 int text1_length, const void* text1_data,
1378 int text2_length, const void* text2_data)
1379{
1380 PyObject* callback = (PyObject*)context;
1381 PyObject* string1 = 0;
1382 PyObject* string2 = 0;
Georg Brandldfd73442009-04-05 11:47:34 +00001383#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001384 PyGILState_STATE gilstate;
Georg Brandldfd73442009-04-05 11:47:34 +00001385#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001386 PyObject* retval = NULL;
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +02001387 long longval;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001388 int result = 0;
Georg Brandldfd73442009-04-05 11:47:34 +00001389#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001390 gilstate = PyGILState_Ensure();
Georg Brandldfd73442009-04-05 11:47:34 +00001391#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001392
1393 if (PyErr_Occurred()) {
1394 goto finally;
1395 }
1396
Guido van Rossum98297ee2007-11-06 21:34:58 +00001397 string1 = PyUnicode_FromStringAndSize((const char*)text1_data, text1_length);
1398 string2 = PyUnicode_FromStringAndSize((const char*)text2_data, text2_length);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001399
1400 if (!string1 || !string2) {
1401 goto finally; /* failed to allocate strings */
1402 }
1403
1404 retval = PyObject_CallFunctionObjArgs(callback, string1, string2, NULL);
1405
1406 if (!retval) {
1407 /* execution failed */
1408 goto finally;
1409 }
1410
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +02001411 longval = PyLong_AsLongAndOverflow(retval, &result);
1412 if (longval == -1 && PyErr_Occurred()) {
1413 PyErr_Clear();
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001414 result = 0;
1415 }
Serhiy Storchaka3cf96ac2013-02-07 17:01:47 +02001416 else if (!result) {
1417 if (longval > 0)
1418 result = 1;
1419 else if (longval < 0)
1420 result = -1;
1421 }
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001422
1423finally:
1424 Py_XDECREF(string1);
1425 Py_XDECREF(string2);
1426 Py_XDECREF(retval);
Georg Brandldfd73442009-04-05 11:47:34 +00001427#ifdef WITH_THREAD
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001428 PyGILState_Release(gilstate);
Georg Brandldfd73442009-04-05 11:47:34 +00001429#endif
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001430 return result;
1431}
1432
1433static PyObject *
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001434pysqlite_connection_interrupt(pysqlite_Connection* self, PyObject* args)
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001435{
1436 PyObject* retval = NULL;
1437
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001438 if (!pysqlite_check_connection(self)) {
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001439 goto finally;
1440 }
1441
1442 sqlite3_interrupt(self->db);
1443
1444 Py_INCREF(Py_None);
1445 retval = Py_None;
1446
1447finally:
1448 return retval;
1449}
1450
Christian Heimesbbe741d2008-03-28 10:53:29 +00001451/* Function author: Paul Kippes <kippesp@gmail.com>
1452 * Class method of Connection to call the Python function _iterdump
1453 * of the sqlite3 module.
1454 */
1455static PyObject *
1456pysqlite_connection_iterdump(pysqlite_Connection* self, PyObject* args)
1457{
1458 PyObject* retval = NULL;
1459 PyObject* module = NULL;
1460 PyObject* module_dict;
1461 PyObject* pyfn_iterdump;
1462
1463 if (!pysqlite_check_connection(self)) {
1464 goto finally;
1465 }
1466
1467 module = PyImport_ImportModule(MODULE_NAME ".dump");
1468 if (!module) {
1469 goto finally;
1470 }
1471
1472 module_dict = PyModule_GetDict(module);
1473 if (!module_dict) {
1474 goto finally;
1475 }
1476
1477 pyfn_iterdump = PyDict_GetItemString(module_dict, "_iterdump");
1478 if (!pyfn_iterdump) {
1479 PyErr_SetString(pysqlite_OperationalError, "Failed to obtain _iterdump() reference");
1480 goto finally;
1481 }
1482
1483 args = PyTuple_New(1);
1484 if (!args) {
1485 goto finally;
1486 }
1487 Py_INCREF(self);
1488 PyTuple_SetItem(args, 0, (PyObject*)self);
1489 retval = PyObject_CallObject(pyfn_iterdump, args);
1490
1491finally:
1492 Py_XDECREF(args);
1493 Py_XDECREF(module);
1494 return retval;
1495}
1496
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001497static PyObject *
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001498pysqlite_connection_create_collation(pysqlite_Connection* self, PyObject* args)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001499{
1500 PyObject* callable;
1501 PyObject* uppercase_name = 0;
1502 PyObject* name;
1503 PyObject* retval;
Victor Stinner35466c52010-04-22 11:23:23 +00001504 Py_ssize_t i, len;
Martin v. Löwisbd928fe2011-10-14 10:20:37 +02001505 _Py_IDENTIFIER(upper);
Victor Stinner35466c52010-04-22 11:23:23 +00001506 char *uppercase_name_str;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001507 int rc;
Martin v. Löwisd63a3b82011-09-28 07:41:54 +02001508 unsigned int kind;
1509 void *data;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001510
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001511 if (!pysqlite_check_thread(self) || !pysqlite_check_connection(self)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001512 goto finally;
1513 }
1514
Gerhard Häring6d214562007-08-10 18:15:11 +00001515 if (!PyArg_ParseTuple(args, "O!O:create_collation(name, callback)", &PyUnicode_Type, &name, &callable)) {
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001516 goto finally;
1517 }
1518
Martin v. Löwisafe55bb2011-10-09 10:38:36 +02001519 uppercase_name = _PyObject_CallMethodId(name, &PyId_upper, "");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001520 if (!uppercase_name) {
1521 goto finally;
1522 }
1523
Martin v. Löwisd63a3b82011-09-28 07:41:54 +02001524 if (PyUnicode_READY(uppercase_name))
1525 goto finally;
1526 len = PyUnicode_GET_LENGTH(uppercase_name);
1527 kind = PyUnicode_KIND(uppercase_name);
1528 data = PyUnicode_DATA(uppercase_name);
1529 for (i=0; i<len; i++) {
1530 Py_UCS4 ch = PyUnicode_READ(kind, data, i);
1531 if ((ch >= '0' && ch <= '9')
1532 || (ch >= 'A' && ch <= 'Z')
1533 || (ch == '_'))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001534 {
Victor Stinner35466c52010-04-22 11:23:23 +00001535 continue;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001536 } else {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001537 PyErr_SetString(pysqlite_ProgrammingError, "invalid character in collation name");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001538 goto finally;
1539 }
1540 }
1541
Victor Stinner35466c52010-04-22 11:23:23 +00001542 uppercase_name_str = _PyUnicode_AsString(uppercase_name);
1543 if (!uppercase_name_str)
1544 goto finally;
1545
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001546 if (callable != Py_None && !PyCallable_Check(callable)) {
1547 PyErr_SetString(PyExc_TypeError, "parameter must be callable");
1548 goto finally;
1549 }
1550
1551 if (callable != Py_None) {
Gerhard Häringf9cee222010-03-05 15:20:03 +00001552 if (PyDict_SetItem(self->collations, uppercase_name, callable) == -1)
1553 goto finally;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001554 } else {
Gerhard Häringf9cee222010-03-05 15:20:03 +00001555 if (PyDict_DelItem(self->collations, uppercase_name) == -1)
1556 goto finally;
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001557 }
1558
1559 rc = sqlite3_create_collation(self->db,
Victor Stinner35466c52010-04-22 11:23:23 +00001560 uppercase_name_str,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001561 SQLITE_UTF8,
1562 (callable != Py_None) ? callable : NULL,
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001563 (callable != Py_None) ? pysqlite_collation_callback : NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001564 if (rc != SQLITE_OK) {
1565 PyDict_DelItem(self->collations, uppercase_name);
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001566 _pysqlite_seterror(self->db, NULL);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001567 goto finally;
1568 }
1569
1570finally:
1571 Py_XDECREF(uppercase_name);
1572
1573 if (PyErr_Occurred()) {
1574 retval = NULL;
1575 } else {
1576 Py_INCREF(Py_None);
1577 retval = Py_None;
1578 }
1579
1580 return retval;
1581}
1582
Christian Heimesbbe741d2008-03-28 10:53:29 +00001583/* Called when the connection is used as a context manager. Returns itself as a
1584 * convenience to the caller. */
1585static PyObject *
1586pysqlite_connection_enter(pysqlite_Connection* self, PyObject* args)
1587{
1588 Py_INCREF(self);
1589 return (PyObject*)self;
1590}
1591
1592/** Called when the connection is used as a context manager. If there was any
1593 * exception, a rollback takes place; otherwise we commit. */
1594static PyObject *
1595pysqlite_connection_exit(pysqlite_Connection* self, PyObject* args)
1596{
1597 PyObject* exc_type, *exc_value, *exc_tb;
1598 char* method_name;
1599 PyObject* result;
1600
1601 if (!PyArg_ParseTuple(args, "OOO", &exc_type, &exc_value, &exc_tb)) {
1602 return NULL;
1603 }
1604
1605 if (exc_type == Py_None && exc_value == Py_None && exc_tb == Py_None) {
1606 method_name = "commit";
1607 } else {
1608 method_name = "rollback";
1609 }
1610
1611 result = PyObject_CallMethod((PyObject*)self, method_name, "");
1612 if (!result) {
1613 return NULL;
1614 }
1615 Py_DECREF(result);
1616
1617 Py_RETURN_FALSE;
1618}
1619
Serhiy Storchaka2d06e842015-12-25 19:53:18 +02001620static const char connection_doc[] =
Thomas Wouters477c8d52006-05-27 19:21:47 +00001621PyDoc_STR("SQLite database connection object.");
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001622
1623static PyGetSetDef connection_getset[] = {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001624 {"isolation_level", (getter)pysqlite_connection_get_isolation_level, (setter)pysqlite_connection_set_isolation_level},
1625 {"total_changes", (getter)pysqlite_connection_get_total_changes, (setter)0},
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001626 {NULL}
1627};
1628
1629static PyMethodDef connection_methods[] = {
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001630 {"cursor", (PyCFunction)pysqlite_connection_cursor, METH_VARARGS|METH_KEYWORDS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001631 PyDoc_STR("Return a cursor for the connection.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001632 {"close", (PyCFunction)pysqlite_connection_close, METH_NOARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001633 PyDoc_STR("Closes the connection.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001634 {"commit", (PyCFunction)pysqlite_connection_commit, METH_NOARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001635 PyDoc_STR("Commit the current transaction.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001636 {"rollback", (PyCFunction)pysqlite_connection_rollback, METH_NOARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001637 PyDoc_STR("Roll back the current transaction.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001638 {"create_function", (PyCFunction)pysqlite_connection_create_function, METH_VARARGS|METH_KEYWORDS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001639 PyDoc_STR("Creates a new function. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001640 {"create_aggregate", (PyCFunction)pysqlite_connection_create_aggregate, METH_VARARGS|METH_KEYWORDS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001641 PyDoc_STR("Creates a new aggregate. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001642 {"set_authorizer", (PyCFunction)pysqlite_connection_set_authorizer, METH_VARARGS|METH_KEYWORDS,
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001643 PyDoc_STR("Sets authorizer callback. Non-standard.")},
Gerhard Häringf9cee222010-03-05 15:20:03 +00001644 #ifdef HAVE_LOAD_EXTENSION
1645 {"enable_load_extension", (PyCFunction)pysqlite_enable_load_extension, METH_VARARGS,
1646 PyDoc_STR("Enable dynamic loading of SQLite extension modules. Non-standard.")},
1647 {"load_extension", (PyCFunction)pysqlite_load_extension, METH_VARARGS,
1648 PyDoc_STR("Load SQLite extension module. Non-standard.")},
1649 #endif
Gerhard Häringe7ea7452008-03-29 00:45:29 +00001650 {"set_progress_handler", (PyCFunction)pysqlite_connection_set_progress_handler, METH_VARARGS|METH_KEYWORDS,
1651 PyDoc_STR("Sets progress handler callback. Non-standard.")},
Antoine Pitrou5bfa0622011-04-04 00:12:04 +02001652 {"set_trace_callback", (PyCFunction)pysqlite_connection_set_trace_callback, METH_VARARGS|METH_KEYWORDS,
1653 PyDoc_STR("Sets a trace callback called for each SQL statement (passed as unicode). Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001654 {"execute", (PyCFunction)pysqlite_connection_execute, METH_VARARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001655 PyDoc_STR("Executes a SQL statement. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001656 {"executemany", (PyCFunction)pysqlite_connection_executemany, METH_VARARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001657 PyDoc_STR("Repeatedly executes a SQL statement. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001658 {"executescript", (PyCFunction)pysqlite_connection_executescript, METH_VARARGS,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001659 PyDoc_STR("Executes a multiple SQL statements at once. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001660 {"create_collation", (PyCFunction)pysqlite_connection_create_collation, METH_VARARGS,
Thomas Wouters477c8d52006-05-27 19:21:47 +00001661 PyDoc_STR("Creates a collation function. Non-standard.")},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001662 {"interrupt", (PyCFunction)pysqlite_connection_interrupt, METH_NOARGS,
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001663 PyDoc_STR("Abort any pending database operation. Non-standard.")},
Christian Heimesbbe741d2008-03-28 10:53:29 +00001664 {"iterdump", (PyCFunction)pysqlite_connection_iterdump, METH_NOARGS,
Benjamin Petersond7b03282008-09-13 15:58:53 +00001665 PyDoc_STR("Returns iterator to the dump of the database in an SQL text format. Non-standard.")},
Christian Heimesbbe741d2008-03-28 10:53:29 +00001666 {"__enter__", (PyCFunction)pysqlite_connection_enter, METH_NOARGS,
1667 PyDoc_STR("For context manager. Non-standard.")},
1668 {"__exit__", (PyCFunction)pysqlite_connection_exit, METH_VARARGS,
1669 PyDoc_STR("For context manager. Non-standard.")},
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001670 {NULL, NULL}
1671};
1672
1673static struct PyMemberDef connection_members[] =
1674{
Guido van Rossum10f07c42007-08-11 15:32:55 +00001675 {"Warning", T_OBJECT, offsetof(pysqlite_Connection, Warning), READONLY},
1676 {"Error", T_OBJECT, offsetof(pysqlite_Connection, Error), READONLY},
1677 {"InterfaceError", T_OBJECT, offsetof(pysqlite_Connection, InterfaceError), READONLY},
1678 {"DatabaseError", T_OBJECT, offsetof(pysqlite_Connection, DatabaseError), READONLY},
1679 {"DataError", T_OBJECT, offsetof(pysqlite_Connection, DataError), READONLY},
1680 {"OperationalError", T_OBJECT, offsetof(pysqlite_Connection, OperationalError), READONLY},
1681 {"IntegrityError", T_OBJECT, offsetof(pysqlite_Connection, IntegrityError), READONLY},
1682 {"InternalError", T_OBJECT, offsetof(pysqlite_Connection, InternalError), READONLY},
1683 {"ProgrammingError", T_OBJECT, offsetof(pysqlite_Connection, ProgrammingError), READONLY},
1684 {"NotSupportedError", T_OBJECT, offsetof(pysqlite_Connection, NotSupportedError), READONLY},
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001685 {"row_factory", T_OBJECT, offsetof(pysqlite_Connection, row_factory)},
1686 {"text_factory", T_OBJECT, offsetof(pysqlite_Connection, text_factory)},
R. David Murrayd35251d2010-06-01 01:32:12 +00001687 {"in_transaction", T_BOOL, offsetof(pysqlite_Connection, inTransaction), READONLY},
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001688 {NULL}
1689};
1690
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001691PyTypeObject pysqlite_ConnectionType = {
Martin v. Löwis9f2e3462007-07-21 17:22:18 +00001692 PyVarObject_HEAD_INIT(NULL, 0)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001693 MODULE_NAME ".Connection", /* tp_name */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001694 sizeof(pysqlite_Connection), /* tp_basicsize */
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001695 0, /* tp_itemsize */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001696 (destructor)pysqlite_connection_dealloc, /* tp_dealloc */
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001697 0, /* tp_print */
1698 0, /* tp_getattr */
1699 0, /* tp_setattr */
Mark Dickinsone94c6792009-02-02 20:36:42 +00001700 0, /* tp_reserved */
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001701 0, /* tp_repr */
1702 0, /* tp_as_number */
1703 0, /* tp_as_sequence */
1704 0, /* tp_as_mapping */
1705 0, /* tp_hash */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001706 (ternaryfunc)pysqlite_connection_call, /* tp_call */
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001707 0, /* tp_str */
1708 0, /* tp_getattro */
1709 0, /* tp_setattro */
1710 0, /* tp_as_buffer */
1711 Py_TPFLAGS_DEFAULT|Py_TPFLAGS_BASETYPE, /* tp_flags */
1712 connection_doc, /* tp_doc */
1713 0, /* tp_traverse */
1714 0, /* tp_clear */
1715 0, /* tp_richcompare */
1716 0, /* tp_weaklistoffset */
1717 0, /* tp_iter */
1718 0, /* tp_iternext */
1719 connection_methods, /* tp_methods */
1720 connection_members, /* tp_members */
1721 connection_getset, /* tp_getset */
1722 0, /* tp_base */
1723 0, /* tp_dict */
1724 0, /* tp_descr_get */
1725 0, /* tp_descr_set */
1726 0, /* tp_dictoffset */
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001727 (initproc)pysqlite_connection_init, /* tp_init */
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001728 0, /* tp_alloc */
1729 0, /* tp_new */
1730 0 /* tp_free */
1731};
1732
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001733extern int pysqlite_connection_setup_types(void)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001734{
Thomas Woutersfc7bb8c2007-01-15 15:49:28 +00001735 pysqlite_ConnectionType.tp_new = PyType_GenericNew;
1736 return PyType_Ready(&pysqlite_ConnectionType);
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001737}