diff options
| author | Tom Lane <tgl@sss.pgh.pa.us> | 2010-12-19 12:48:48 -0500 | 
|---|---|---|
| committer | Tom Lane <tgl@sss.pgh.pa.us> | 2010-12-19 12:48:48 -0500 | 
| commit | 15884d494e620218d1618c491bf6e09860a863f2 (patch) | |
| tree | c14b9478536571eb3e4889605d9a5c16118746b3 /contrib/intarray | |
| parent | 2bb6050c453d4015478a2cc27a088119d963b1ed (diff) | |
Fix erroneous parsing of tsquery input "... & !(subexpression) | ..."
After parsing a parenthesized subexpression, we must pop all pending
ANDs and NOTs off the stack, just like the case for a simple operand.
Per bug #5793.
Also fix clones of this routine in contrib/intarray and contrib/ltree,
where input of types query_int and ltxtquery had the same problem.
Back-patch to all supported versions.
Diffstat (limited to 'contrib/intarray')
| -rw-r--r-- | contrib/intarray/_int_bool.c | 4 | 
1 files changed, 2 insertions, 2 deletions
diff --git a/contrib/intarray/_int_bool.c b/contrib/intarray/_int_bool.c index 438db2ca95d..93901066116 100644 --- a/contrib/intarray/_int_bool.c +++ b/contrib/intarray/_int_bool.c @@ -196,8 +196,8 @@ makepol(WORKSTATE *state)  			case OPEN:  				if (makepol(state) == ERR)  					return ERR; -				if (lenstack && (stack[lenstack - 1] == (int4) '&' || -								 stack[lenstack - 1] == (int4) '!')) +				while (lenstack && (stack[lenstack - 1] == (int4) '&' || +									stack[lenstack - 1] == (int4) '!'))  				{  					lenstack--;  					pushquery(state, OPR, stack[lenstack]);  | 
