aboutsummaryrefslogtreecommitdiff
path: root/src/backend/access/transam/commit_ts.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2022-01-17 13:30:04 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2022-01-17 13:30:04 -0500
commit6d1a854c157eb4a139e06f19a8cd1b53bdec7e6f (patch)
treee48b264e59699d302efa2cddd88359e81d7f0d33 /src/backend/access/transam/commit_ts.c
parent38f099ef935b34388af2ae52c1098d2c9773465a (diff)
downloadpostgresql-6d1a854c157eb4a139e06f19a8cd1b53bdec7e6f.tar.gz
postgresql-6d1a854c157eb4a139e06f19a8cd1b53bdec7e6f.zip
Avoid calling gettext() in signal handlers.
It seems highly unlikely that gettext() can be relied on to be async-signal-safe. psql used to understand that, but someone got it wrong long ago in the src/bin/scripts/ version of handle_sigint, and then the bad idea was perpetuated when those two versions were unified into src/fe_utils/cancel.c. I'm unsure why there have not been field complaints about this ... maybe gettext() is signal-safe once it's translated at least one message? But we have no business assuming any such thing. In cancel.c (v13 and up), I preserved our ability to localize "Cancel request sent" messages by invoking gettext() before the signal handler is set up. In earlier branches I just made src/bin/scripts/ not localize those messages, as psql did then. (Just for extra unsafety, the src/bin/scripts/ version was invoking fprintf() from a signal handler. Sigh.) Noted while fixing signal-safety issues in PQcancel() itself. Back-patch to all supported branches. Discussion: https://postgr.es/m/2937814.1641960929@sss.pgh.pa.us
Diffstat (limited to 'src/backend/access/transam/commit_ts.c')
0 files changed, 0 insertions, 0 deletions