Re: Add \pset options for boolean value display

From: "a(dot)kozhemyakin" <a(dot)kozhemyakin(at)postgrespro(dot)ru>
To: pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Re: Add \pset options for boolean value display
Date: 2026-04-21 06:10:07
Message-ID: 83e247ed-0b2d-4aba-bc42-e7bbc20be0d6@postgrespro.ru
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi Hackers,

The following script, when built with addresssanitizer, fails with a
DoubleFree error. reproduce on master (d3bba0415435)

psql postgres <<EOF
\pset display_false 'f'
SELECT 1 as one, 2 as two \g (display_false=csv csv_fieldsep='\t')
\pset display_false 'f'
EOF
Boolean false display is "f".
one | two
-----+-----
1 | 2
(1 строка)

=================================================================
==2263488==ERROR: AddressSanitizer: attempting double-free on
0x774e419e15d0 in thread T0:
    #0 0x64c15cb777ab in free.part.0
(/pgpro/builds/master/inst_asan/bin/psql+0x23e7ab) (BuildId:
235e8c12978fc34235af5b00bd4a2feaab9cb794)
    #1 0x64c15cbedfbd in do_pset
/pgpro/postgres/src/bin/psql/command.c:5310
    #2 0x64c15cbef308 in exec_command_pset
/pgpro/postgres/src/bin/psql/command.c:2737
    #3 0x64c15cbf10d3 in exec_command
/pgpro/postgres/src/bin/psql/command.c:431
    #4 0x64c15cbf1579 in HandleSlashCmds
/pgpro/postgres/src/bin/psql/command.c:258
    #5 0x64c15cc25ecd in MainLoop
/pgpro/postgres/src/bin/psql/mainloop.c:496
    #6 0x64c15cbec791 in process_file
/pgpro/postgres/src/bin/psql/command.c:4977
    #7 0x64c15cc48cda in main /pgpro/postgres/src/bin/psql/startup.c:424
    #8 0x7b2e4322a574 in __libc_start_call_main
../sysdeps/nptl/libc_start_call_main.h:58
    #9 0x7b2e4322a627 in __libc_start_main_impl ../csu/libc-start.c:360
    #10 0x64c15ca91b84 in _start
(/pgpro/builds/master/inst_asan/bin/psql+0x158b84) (BuildId:
235e8c12978fc34235af5b00bd4a2feaab9cb794)

0x774e419e15d0 is located 0 bytes inside of 2-byte region
[0x774e419e15d0,0x774e419e15d2)
freed by thread T0 here:
    #0 0x64c15cb777ab in free.part.0
(/pgpro/builds/master/inst_asan/bin/psql+0x23e7ab) (BuildId:
235e8c12978fc34235af5b00bd4a2feaab9cb794)
    #1 0x64c15cbedfbd in do_pset
/pgpro/postgres/src/bin/psql/command.c:5310
    #2 0x783e419e2980  (<unknown module>)

previously allocated by thread T0 here:
    #0 0x64c15cb725c8 in strdup
(/pgpro/builds/master/inst_asan/bin/psql+0x2395c8) (BuildId:
235e8c12978fc34235af5b00bd4a2feaab9cb794)
    #1 0x64c15cc92bd5 in pg_strdup
/pgpro/postgres/src/common/fe_memutils.c:95

SUMMARY: AddressSanitizer: double-free
(/pgpro/builds/master/inst_asan/bin/psql+0x23e7ab) (BuildId:
235e8c12978fc34235af5b00bd4a2feaab9cb794) in free.part.0
==2263488==ABORTING

645cb44c5490f70da4dca57b8ecca6562fb883a7 is the first bad commit

gcc --version
gcc (Ubuntu 15.2.0-4ubuntu4) 15.2.0

building CPPFLAGS="-Og -fsanitize=address -fsanitize=undefined
-fno-sanitize-recover=all -fno-sanitize=nonnull-attribute
-fstack-protector" LDFLAGS='-fsanitize=address -fsanitize=undefined
-static-libasan' \
./configure --prefix /pgpro/builds/master_simple && make world-bin -s
-j$(nproc) && make install-world-bin -s

04.11.2025 00:16, David G. Johnston пишет:
> On Monday, November 3, 2025, Álvaro Herrera <alvherre(at)kurilemu(dot)de> wrote:
>
> On 2025-Oct-21, Álvaro Herrera wrote:
> > On 2025-Oct-20, David G. Johnston wrote:
> > > Thank you.  Seems good from a quick read.  I’m regretting the
> choice of the
> > > display_ prefix; is there any technical limitation or other
> opposition to
> > > using just true and false?
> > >
> > > \pset true ‘true’
> > > \pset false ‘false’
>
> > Uhm.  I don't know.  [...]  I'll gladly take a vote.
>
> I got zero votes and lots of digression, so I have pushed with your
> original choice of "display_true" and "display_false".  The "true" and
> "false" variable names sound too generic and I think they're more
> likely
> to cause confusion.  I think "null" is not a great name either,
> but it's
> been there since forever so I'm not going to propose changing it.
>
>
> Thank you.
>
> David J.
>

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Alex Guo 2026-04-21 06:12:24 Re: [PATCH] Fix column name escaping in postgres_fdw stats import
Previous Message Antonin Houska 2026-04-21 06:09:42 Re: repack: fix a bug to reject deferrable primary key fallback for concurrent mode