Must free the pgParameterStatus chain in freePGconn(). My fault,
authorTom Lane <tgl@sss.pgh.pa.us>
Sat, 18 Oct 2003 05:02:06 +0000 (05:02 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Sat, 18 Oct 2003 05:02:06 +0000 (05:02 +0000)
well spotted by Neil Conway.

src/interfaces/libpq/fe-connect.c

index cd235a1276839b97e358d9e343b6d516bf24055a..9dde3043c709bb21c4914b85d52369aaa9e56ece 100644 (file)
@@ -8,7 +8,7 @@
  *
  *
  * IDENTIFICATION
- *   $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.262 2003/10/02 19:52:44 tgl Exp $
+ *   $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.263 2003/10/18 05:02:06 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -2003,8 +2003,11 @@ makeEmptyPGconn(void)
 static void
 freePGconn(PGconn *conn)
 {
+   pgParameterStatus *pstatus;
+
    if (!conn)
        return;
+
    pqClearAsyncResult(conn);   /* deallocate result and curTuple */
    if (conn->sock >= 0)
    {
@@ -2037,6 +2040,14 @@ freePGconn(PGconn *conn)
    if (conn->notifyList)
        DLFreeList(conn->notifyList);
    freeaddrinfo_all(conn->addrlist_family, conn->addrlist);
+   pstatus = conn->pstatus;
+   while (pstatus != NULL)
+   {
+       pgParameterStatus *prev = pstatus;
+
+       pstatus = pstatus->next;
+       free(prev);
+   }
    if (conn->lobjfuncs)
        free(conn->lobjfuncs);
    if (conn->inBuffer)