mirror of
https://github.com/postgres/postgres.git
synced 2025-06-14 18:42:34 +03:00
Report Python errors from iterators with PLy_elog
This improves reporting, as the error string now includes the actual Python exception. As a side effect, this no longer sets the errcode to ERRCODE_DATA_EXCEPTION, which might be considered a feature, as it's not documented and not clear why iterator errors should be treated differently. Jan Urbański
This commit is contained in:
@ -1157,9 +1157,7 @@ PLy_function_handler(FunctionCallInfo fcinfo, PLyProcedure *proc)
|
||||
PLy_function_delete_args(proc);
|
||||
|
||||
if (has_error)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_DATA_EXCEPTION),
|
||||
errmsg("error fetching next item from iterator")));
|
||||
PLy_elog(ERROR, "error fetching next item from iterator");
|
||||
|
||||
/* Disconnect from the SPI manager before returning */
|
||||
if (SPI_finish() != SPI_OK_FINISH)
|
||||
|
Reference in New Issue
Block a user