From: Tom Lane Date: Mon, 3 Oct 2011 16:13:15 +0000 (-0400) Subject: ProcedureCreate neglected to record dependencies on default expressions. X-Git-Url: http://git.postgresql.org/gitweb/?a=commitdiff_plain;h=76074fcaa04fb5d35e8cf7716587440e3d075d50;p=users%2Fkgrittn%2Fpostgres.git ProcedureCreate neglected to record dependencies on default expressions. Thus, an object referenced in a default expression could be dropped while the function remained present. This was unaccountably missed in the original patch to add default parameters for functions. Reported by Pavel Stehule. --- diff --git a/src/backend/catalog/pg_proc.c b/src/backend/catalog/pg_proc.c index f2b78b66a4..5f7d7f6b68 100644 --- a/src/backend/catalog/pg_proc.c +++ b/src/backend/catalog/pg_proc.c @@ -599,6 +599,11 @@ ProcedureCreate(const char *procedureName, recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); } + /* dependency on parameter default expressions */ + if (parameterDefaults) + recordDependencyOnExpr(&myself, (Node *) parameterDefaults, + NIL, DEPENDENCY_NORMAL); + /* dependency on owner */ if (!is_update) recordDependencyOnOwner(ProcedureRelationId, retval, proowner);