Fix oversight in pg_dump's handling of extension configuration tables.

If an extension has not been selected to be dumped (perhaps because of
a --schema or --table switch), the contents of its configuration tables
surely should not get dumped either.  Per gripe from
Hubert Depesz Lubaczewski.
This commit is contained in:
Tom Lane 2012-02-10 15:22:14 -05:00
parent 97dc3c8a14
commit 59de132f9a

View File

@ -14179,13 +14179,18 @@ getExtensionMembership(Archive *fout, ExtensionInfo extinfo[],
*/ */
for (i = 0; i < numExtensions; i++) for (i = 0; i < numExtensions; i++)
{ {
char *extconfig = extinfo[i].extconfig; ExtensionInfo *curext = &(extinfo[i]);
char *extcondition = extinfo[i].extcondition; char *extconfig = curext->extconfig;
char *extcondition = curext->extcondition;
char **extconfigarray = NULL; char **extconfigarray = NULL;
char **extconditionarray = NULL; char **extconditionarray = NULL;
int nconfigitems; int nconfigitems;
int nconditionitems; int nconditionitems;
/* Tables of not-to-be-dumped extensions shouldn't be dumped */
if (!curext->dobj.dump)
continue;
if (parsePGArray(extconfig, &extconfigarray, &nconfigitems) && if (parsePGArray(extconfig, &extconfigarray, &nconfigitems) &&
parsePGArray(extcondition, &extconditionarray, &nconditionitems) && parsePGArray(extcondition, &extconditionarray, &nconditionitems) &&
nconfigitems == nconditionitems) nconfigitems == nconditionitems)