aboutsummaryrefslogtreecommitdiff
path: root/src/backend/parser/parse_agg.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2023-03-11 12:15:41 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2023-03-11 12:15:41 -0500
commit1279414bc613316d3cb7216790bc943d5af8be70 (patch)
treefed83d539b07857a72fbc58e44544c4f65236496 /src/backend/parser/parse_agg.c
parenta30310833d071cfe9c1e7a9768e4d4df47685106 (diff)
downloadpostgresql-1279414bc613316d3cb7216790bc943d5af8be70.tar.gz
postgresql-1279414bc613316d3cb7216790bc943d5af8be70.zip
Fix misbehavior in contrib/pg_trgm with an unsatisfiable regex.
If the regex compiler can see that a regex is unsatisfiable (for example, '$foo') then it may emit an NFA having no arcs. pg_trgm's packGraph function did the wrong thing in this case; it would access off the end of a work array, and with bad luck could produce a corrupted output data structure causing more problems later. This could end with wrong answers or crashes in queries using a pg_trgm GIN or GiST index with such a regex. Fix by not trying to de-duplicate if there aren't at least 2 arcs. Per bug #17830 from Alexander Lakhin. Back-patch to all supported branches. Discussion: https://postgr.es/m/17830-57ff5f89bdb02b09@postgresql.org
Diffstat (limited to 'src/backend/parser/parse_agg.c')
0 files changed, 0 insertions, 0 deletions