Commit 7b96519f authored by Tom Lane's avatar Tom Lane

Don't mark auto-generated types as extension members.

Relation rowtypes and automatically-generated array types do not need to
have their own extension membership dependency entries.  If we create such
then it becomes more difficult to remove items from an extension, and it's
also harder for an extension upgrade script to make sure it duplicates the
dependencies created by the extension's regular installation script.

I changed the code in such a way that this happened in commit
988cccc6, I think because of worries about
the shell-type-replacement case; but that cure was worse than the disease.
It would only matter if one extension created a shell type that was
replaced with an auto-generated type in another extension, which seems
pretty far-fetched.  Better to make this work unsurprisingly in normal
cases.

Report and patch by Robert Haas, comment adjustments by me.
parent e0b268fb
...@@ -480,7 +480,11 @@ TypeCreate(Oid newTypeOid, ...@@ -480,7 +480,11 @@ TypeCreate(Oid newTypeOid,
* *
* If rebuild is true, we remove existing dependencies and rebuild them * If rebuild is true, we remove existing dependencies and rebuild them
* from scratch. This is needed for ALTER TYPE, and also when replacing * from scratch. This is needed for ALTER TYPE, and also when replacing
* a shell type. * a shell type. We don't remove an existing extension dependency, though.
* (That means an extension can't absorb a shell type created in another
* extension, nor ALTER a type created by another extension. Also, if it
* replaces a free-standing shell type or ALTERs a free-standing type,
* that type will become a member of the extension.)
*/ */
void void
GenerateTypeDependencies(Oid typeNamespace, GenerateTypeDependencies(Oid typeNamespace,
...@@ -505,6 +509,7 @@ GenerateTypeDependencies(Oid typeNamespace, ...@@ -505,6 +509,7 @@ GenerateTypeDependencies(Oid typeNamespace,
ObjectAddress myself, ObjectAddress myself,
referenced; referenced;
/* If rebuild, first flush old dependencies, except extension deps */
if (rebuild) if (rebuild)
{ {
deleteDependencyRecordsFor(TypeRelationId, typeObjectId, true); deleteDependencyRecordsFor(TypeRelationId, typeObjectId, true);
...@@ -516,7 +521,7 @@ GenerateTypeDependencies(Oid typeNamespace, ...@@ -516,7 +521,7 @@ GenerateTypeDependencies(Oid typeNamespace,
myself.objectSubId = 0; myself.objectSubId = 0;
/* /*
* Make dependency on namespace and shared dependency on owner. * Make dependencies on namespace, owner, extension.
* *
* For a relation rowtype (that's not a composite type), we should skip * For a relation rowtype (that's not a composite type), we should skip
* these because we'll depend on them indirectly through the pg_class * these because we'll depend on them indirectly through the pg_class
...@@ -532,10 +537,9 @@ GenerateTypeDependencies(Oid typeNamespace, ...@@ -532,10 +537,9 @@ GenerateTypeDependencies(Oid typeNamespace,
recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL); recordDependencyOn(&myself, &referenced, DEPENDENCY_NORMAL);
recordDependencyOnOwner(TypeRelationId, typeObjectId, owner); recordDependencyOnOwner(TypeRelationId, typeObjectId, owner);
}
/* dependency on extension */
recordDependencyOnCurrentExtension(&myself, rebuild); recordDependencyOnCurrentExtension(&myself, rebuild);
}
/* Normal dependencies on the I/O functions */ /* Normal dependencies on the I/O functions */
if (OidIsValid(inputProcedure)) if (OidIsValid(inputProcedure))
......
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