mirror of
https://github.com/postgres/postgres.git
synced 2025-07-26 01:22:12 +03:00
Allow a context to be passed in for error handling
As pointed out by Tom Lane, we can allow other users of the error handler callbacks to provide their own memory context by adding the context to use to ErrorData and using that instead of explicitly using ErrorContext. This then allows GetErrorContextStack() to be called from inside exception handlers, so modify plpgsql to take advantage of that and add an associated regression test for it.
This commit is contained in:
@ -895,7 +895,6 @@ stmt_getdiag : K_GET getdiag_area_opt K_DIAGNOSTICS getdiag_list ';'
|
||||
/* these fields are disallowed in stacked case */
|
||||
case PLPGSQL_GETDIAG_ROW_COUNT:
|
||||
case PLPGSQL_GETDIAG_RESULT_OID:
|
||||
case PLPGSQL_GETDIAG_CONTEXT:
|
||||
if (new->is_stacked)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_SYNTAX_ERROR),
|
||||
@ -921,6 +920,9 @@ stmt_getdiag : K_GET getdiag_area_opt K_DIAGNOSTICS getdiag_list ';'
|
||||
plpgsql_getdiag_kindname(ditem->kind)),
|
||||
parser_errposition(@1)));
|
||||
break;
|
||||
/* these fields are allowed in either case */
|
||||
case PLPGSQL_GETDIAG_CONTEXT:
|
||||
break;
|
||||
default:
|
||||
elog(ERROR, "unrecognized diagnostic item kind: %d",
|
||||
ditem->kind);
|
||||
|
Reference in New Issue
Block a user