summaryrefslogtreecommitdiff
path: root/src/include/executor/nodeValuesscan.h
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2011-08-26 16:51:34 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2011-08-26 16:51:34 -0400
commit00eb036c111b8f72a34ca729efccd785761d977e (patch)
treee582c9467bf251e6abdc3af547bd979205b0953c /src/include/executor/nodeValuesscan.h
parent40271811cb9c4906041afc21a3b2c2f31f534fd8 (diff)
Fix potential memory clobber in tsvector_concat().
tsvector_concat() allocated its result workspace using the "conservative" estimate of the sum of the two input tsvectors' sizes. Unfortunately that wasn't so conservative as all that, because it supposed that the number of pad bytes required could not grow. Which it can, as per test case from Jesper Krogh, if there's a mix of lexemes with positions and lexemes without them in the input data. The fix is to assume that we might add a not-previously-present pad byte for each and every lexeme in the two inputs; which really is conservative, but it doesn't seem worthwhile to try to be more precise. This is an aboriginal bug in tsvector_concat, so back-patch to all versions containing it.
Diffstat (limited to 'src/include/executor/nodeValuesscan.h')
0 files changed, 0 insertions, 0 deletions