mirror of
https://git.postgresql.org/git/postgresql.git
synced 2026-02-21 05:46:59 +08:00
Fix expanding 'bounds' in pg_trgm's calc_word_similarity() function
If the 'bounds' array needs to be expanded, because the input contains more trigrams than the initial guess, the code didn't return the reallocated array correctly to the caller. That could lead to a crash in the rare case that the input string becomes longer when it's lower-cased. The only known instance of that is when an ICU locale is used with certain single-byte encodings. This was an oversight in commit 00896ddaf41f. Author: Zsolt Parragi <zsolt.parragi@percona.com> Backpatch-through: 18
This commit is contained in:
@ -533,7 +533,7 @@ generate_trgm_only(growable_trgm_array *dst, char *str, int slen, TrgmBound **bo
|
||||
{
|
||||
if (bounds_allocated < dst->length)
|
||||
{
|
||||
bounds = repalloc0_array(bounds, TrgmBound, bounds_allocated, dst->allocated);
|
||||
bounds = *bounds_p = repalloc0_array(bounds, TrgmBound, bounds_allocated, dst->allocated);
|
||||
bounds_allocated = dst->allocated;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user