pg_dump: Don't leak memory in buildDefaultACLCommands()
authorStephen Frost <sfrost@snowman.net>
Sun, 7 May 2017 02:58:22 +0000 (22:58 -0400)
committerStephen Frost <sfrost@snowman.net>
Sun, 7 May 2017 02:58:22 +0000 (22:58 -0400)
buildDefaultACLCommands() didn't destroy the string buffer created in
certain cases, leading to a memory leak.  Fix by destroying the buffer
before returning from the function.

Spotted by Coverity.

Author: Michael Paquier

Back-patch to 9.6 where buildDefaultACLCommands() was added.

src/bin/pg_dump/dumputils.c

index a062a6b33018f164488107c314595dd7896dd38c..11870a33fa5347310bd82ba8bfd97fef394a4b9d 100644 (file)
@@ -394,13 +394,19 @@ buildDefaultACLCommands(const char *type, const char *nspname,
                appendPQExpBuffer(sql, "SELECT pg_catalog.binary_upgrade_set_record_init_privs(true);\n");
                if (!buildACLCommands("", NULL, type, initacls, initracls, owner,
                                                          prefix->data, remoteVersion, sql))
+               {
+                       destroyPQExpBuffer(prefix);
                        return false;
+               }
                appendPQExpBuffer(sql, "SELECT pg_catalog.binary_upgrade_set_record_init_privs(false);\n");
        }
 
        if (!buildACLCommands("", NULL, type, acls, racls, owner,
                                                  prefix->data, remoteVersion, sql))
+       {
+               destroyPQExpBuffer(prefix);
                return false;
+       }
 
        destroyPQExpBuffer(prefix);