]> granicus.if.org Git - postgresql/commit
Fix miserable coding in pg_stat_get_activity().
authorTom Lane <tgl@sss.pgh.pa.us>
Sat, 10 Sep 2016 17:49:04 +0000 (13:49 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sat, 10 Sep 2016 17:49:04 +0000 (13:49 -0400)
commitfb7ed3889fa6fc0f4aa6718ffb6574801ad12484
tree6e86c74cb0674d2746e2b9bf6009146741ac51fa
parent8778da2af0f4dac23b8d1ef3436b6bb0954bc013
Fix miserable coding in pg_stat_get_activity().

Commit dd1a3bccc replaced a test on whether a subroutine returned a
null pointer with a test on whether &pointer->backendStatus was null.
This accidentally failed to fail, at least on common compilers, because
backendStatus is the first field in the struct; but it was surely trouble
waiting to happen.  Commit f91feba87 then messed things up further,
changing the logic to

local_beentry = pgstat_fetch_stat_local_beentry(curr_backend);
if (!local_beentry)
continue;
beentry = &local_beentry->backendStatus;
if (!beentry)
{

where the second "if" is now dead code, so that the intended behavior of
printing a row with "<backend information not available>" cannot occur.

I suspect this is all moot because pgstat_fetch_stat_local_beentry
will never actually return null in this function's usage, but it's still
very poor coding.  Repair back to 9.4 where the original problem was
introduced.
src/backend/utils/adt/pgstatfuncs.c