]> granicus.if.org Git - postgresql/commit
Fix regexp substring matching (substring(string from pattern)) for the corner
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 19 Mar 2008 02:40:37 +0000 (02:40 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 19 Mar 2008 02:40:37 +0000 (02:40 +0000)
commit965a2a191acdc6fc1cbdd2736a178f4d900e3765
tree5b5c5df4ebde1ccf11528891d0a8afdd70ec36c5
parent8436f9a0364a6a16dbf7b250597986a97c9e6f09
Fix regexp substring matching (substring(string from pattern)) for the corner
case where there is a match to the pattern overall but the user has specified
a parenthesized subexpression and that subexpression hasn't got a match.
An example is substring('foo' from 'foo(bar)?').  This should return NULL,
since (bar) isn't matched, but it was mistakenly returning the whole-pattern
match instead (ie, 'foo').  Per bug #4044 from Rui Martins.

This has been broken since the beginning; patch in all supported versions.
The old behavior was sufficiently inconsistent that it's impossible to believe
anyone is depending on it.
src/backend/utils/adt/regexp.c