pgsql: psql: Fix memory leak with repeated calls of \bind - Mailing list pgsql-committers

From Michael Paquier
Subject pgsql: psql: Fix memory leak with repeated calls of \bind
Date
Msg-id E1srBXz-001kfY-8V@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
psql: Fix memory leak with repeated calls of \bind

Calling \bind repeatedly would cause the memory allocated for the list
of bind parameters to be leaked after each call, as the list is reset
when beginning a single call.

This issue is fixed by making the cleanup of the bind parameter list
more aggressive, refactoring it into a single routine called after
processing a query and before running an individual \bind.

HEAD required more surgery and has been fixed by 87eeadaea143.  Issue
introduced by 5b66de3433e2.

Reported-by: Anthonin Bonnefoy
Discussion: https://postgr.es/m/2e5b89af-a351-ff0a-000c-037ac28314ab@gmail.com
Backpatch-through: 16

Branch
------
REL_17_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/b0ae6db2088bbd1d16733b359c9c300735e9c21e

Modified Files
--------------
src/bin/psql/command.c |  2 +-
src/bin/psql/common.c  | 29 +++++++++++++++++++++--------
src/bin/psql/common.h  |  1 +
3 files changed, 23 insertions(+), 9 deletions(-)


pgsql-committers by date:

Previous
From: Michael Paquier
Date:
Subject: pgsql: psql: Clean up more aggressively state of \bind[_named], \parse
Next
From: Alexander Korotkov
Date:
Subject: pgsql: Move pg_wal_replay_wait() to xlogfuncs.c