]> granicus.if.org Git - postgresql/commitdiff
Add missing PQclear() calls into pg_receivexlog.
authorFujii Masao <fujii@postgresql.org>
Sat, 2 Aug 2014 06:18:09 +0000 (15:18 +0900)
committerFujii Masao <fujii@postgresql.org>
Sat, 2 Aug 2014 06:18:09 +0000 (15:18 +0900)
Back-patch to 9.3.

src/bin/pg_basebackup/receivelog.c

index 99d875be9c5c095edeed3e0446abee9428c3c63d..a260881517de995190e3fccedd8d5d7f322d2770 100644 (file)
@@ -628,6 +628,7 @@ ReceiveXlogStream(PGconn *conn, XLogRecPtr startpos, uint32 timeline,
                                fprintf(stderr,
                                   _("%s: unexpected termination of replication stream: %s"),
                                                progname, PQresultErrorMessage(res));
+                               PQclear(res);
                                goto error;
                        }
                        PQclear(res);
@@ -642,6 +643,8 @@ ReceiveXlogStream(PGconn *conn, XLogRecPtr startpos, uint32 timeline,
                }
                else if (PQresultStatus(res) == PGRES_COMMAND_OK)
                {
+                       PQclear(res);
+
                        /*
                         * End of replication (ie. controlled shut down of the server).
                         *
@@ -663,6 +666,7 @@ ReceiveXlogStream(PGconn *conn, XLogRecPtr startpos, uint32 timeline,
                        fprintf(stderr,
                                        _("%s: unexpected termination of replication stream: %s"),
                                        progname, PQresultErrorMessage(res));
+                       PQclear(res);
                        goto error;
                }
        }
@@ -839,6 +843,7 @@ HandleCopyStream(PGconn *conn, XLogRecPtr startpos, uint32 timeline,
                                                PQclear(res);
                                                goto error;
                                        }
+                                       PQclear(res);
                                        res = PQgetResult(conn);
                                }
                                still_sending = false;