summaryrefslogtreecommitdiffstats
path: root/Modules/_sqlite/connection.c
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-07-22 06:34:32 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2013-07-22 06:34:32 (GMT)
commit3a8573230c0d5b42e3f66ea604fdb86cafeb6366 (patch)
tree526088c5902c2cca48117c64a4e71de917184283 /Modules/_sqlite/connection.c
parentdb53ad7cf16dce2c558e25100d25c1fdae820a6a (diff)
downloadcpython-3a8573230c0d5b42e3f66ea604fdb86cafeb6366.zip
cpython-3a8573230c0d5b42e3f66ea604fdb86cafeb6366.tar.gz
cpython-3a8573230c0d5b42e3f66ea604fdb86cafeb6366.tar.bz2
Issue #18488: Fix _pysqlite_final_callback()
Restore behaviour of Python 3.3: print the finalizer() error if sqlite3.enable_callback_tracebacks() has been called, clear the error otherwise. But keep (save/restore) also the AttributeError raised in _pysqlite_step_callback().
Diffstat (limited to 'Modules/_sqlite/connection.c')
-rw-r--r--Modules/_sqlite/connection.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/Modules/_sqlite/connection.c b/Modules/_sqlite/connection.c
index ed4ae1c..551431c 100644
--- a/Modules/_sqlite/connection.c
+++ b/Modules/_sqlite/connection.c
@@ -718,10 +718,6 @@ void _pysqlite_final_callback(sqlite3_context* context)
function_result = _PyObject_CallMethodId(*aggregate_instance, &PyId_finalize, "");
- /* Restore the exception (if any) of the last call to step(),
- but clear also the current exception if finalize() failed */
- PyErr_Restore(exception, value, tb);
-
Py_DECREF(*aggregate_instance);
ok = 0;
@@ -738,6 +734,10 @@ void _pysqlite_final_callback(sqlite3_context* context)
_sqlite3_result_error(context, "user-defined aggregate's 'finalize' method raised error", -1);
}
+ /* Restore the exception (if any) of the last call to step(),
+ but clear also the current exception if finalize() failed */
+ PyErr_Restore(exception, value, tb);
+
error:
#ifdef WITH_THREAD
PyGILState_Release(threadstate);