Commit 684b4f29 authored by Michael Paquier's avatar Michael Paquier

Refactor creation of normal dependency records when creating extension

When creating an extension, the same type of dependency is used when
registering a dependency to a schema and required extensions.  This
improves the code so as those dependencies are not recorded one-by-one,
but grouped together.  Note that this has as side effect to remove
duplicate dependency entries, even if it should not happen in practice
as extensions listed as required in a control file should be listed only
once.

Extracted from a larger patch by the same author.

Author: Daniel Dustafsson
Discussion: https://postgr.es/m/20200629065535.GA183079@paquier.xyz
parent c4342c93
...@@ -1783,6 +1783,7 @@ InsertExtensionTuple(const char *extName, Oid extOwner, ...@@ -1783,6 +1783,7 @@ InsertExtensionTuple(const char *extName, Oid extOwner,
HeapTuple tuple; HeapTuple tuple;
ObjectAddress myself; ObjectAddress myself;
ObjectAddress nsp; ObjectAddress nsp;
ObjectAddresses *refobjs;
ListCell *lc; ListCell *lc;
/* /*
...@@ -1825,27 +1826,26 @@ InsertExtensionTuple(const char *extName, Oid extOwner, ...@@ -1825,27 +1826,26 @@ InsertExtensionTuple(const char *extName, Oid extOwner,
*/ */
recordDependencyOnOwner(ExtensionRelationId, extensionOid, extOwner); recordDependencyOnOwner(ExtensionRelationId, extensionOid, extOwner);
myself.classId = ExtensionRelationId; refobjs = new_object_addresses();
myself.objectId = extensionOid;
myself.objectSubId = 0;
nsp.classId = NamespaceRelationId; ObjectAddressSet(myself, ExtensionRelationId, extensionOid);
nsp.objectId = schemaOid;
nsp.objectSubId = 0;
recordDependencyOn(&myself, &nsp, DEPENDENCY_NORMAL); ObjectAddressSet(nsp, NamespaceRelationId, schemaOid);
add_exact_object_address(&nsp, refobjs);
foreach(lc, requiredExtensions) foreach(lc, requiredExtensions)
{ {
Oid reqext = lfirst_oid(lc); Oid reqext = lfirst_oid(lc);
ObjectAddress otherext; ObjectAddress otherext;
otherext.classId = ExtensionRelationId; ObjectAddressSet(otherext, ExtensionRelationId, reqext);
otherext.objectId = reqext; add_exact_object_address(&otherext, refobjs);
otherext.objectSubId = 0;
recordDependencyOn(&myself, &otherext, DEPENDENCY_NORMAL);
} }
/* Record all of them (this includes duplicate elimination) */
record_object_address_dependencies(&myself, refobjs, DEPENDENCY_NORMAL);
free_object_addresses(refobjs);
/* Post creation hook for new extension */ /* Post creation hook for new extension */
InvokeObjectPostCreateHook(ExtensionRelationId, extensionOid, 0); InvokeObjectPostCreateHook(ExtensionRelationId, extensionOid, 0);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment