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.
This commit is contained in:
parent
2bb6050c45
commit
15884d494e
@ -196,8 +196,8 @@ makepol(WORKSTATE *state)
|
|||||||
case OPEN:
|
case OPEN:
|
||||||
if (makepol(state) == ERR)
|
if (makepol(state) == ERR)
|
||||||
return ERR;
|
return ERR;
|
||||||
if (lenstack && (stack[lenstack - 1] == (int4) '&' ||
|
while (lenstack && (stack[lenstack - 1] == (int4) '&' ||
|
||||||
stack[lenstack - 1] == (int4) '!'))
|
stack[lenstack - 1] == (int4) '!'))
|
||||||
{
|
{
|
||||||
lenstack--;
|
lenstack--;
|
||||||
pushquery(state, OPR, stack[lenstack]);
|
pushquery(state, OPR, stack[lenstack]);
|
||||||
|
@ -241,8 +241,8 @@ makepol(QPRS_STATE *state)
|
|||||||
case OPEN:
|
case OPEN:
|
||||||
if (makepol(state) == ERR)
|
if (makepol(state) == ERR)
|
||||||
return ERR;
|
return ERR;
|
||||||
if (lenstack && (stack[lenstack - 1] == (int4) '&' ||
|
while (lenstack && (stack[lenstack - 1] == (int4) '&' ||
|
||||||
stack[lenstack - 1] == (int4) '!'))
|
stack[lenstack - 1] == (int4) '!'))
|
||||||
{
|
{
|
||||||
lenstack--;
|
lenstack--;
|
||||||
pushquery(state, OPR, stack[lenstack], 0, 0, 0);
|
pushquery(state, OPR, stack[lenstack], 0, 0, 0);
|
||||||
|
@ -371,8 +371,8 @@ makepol(TSQueryParserState state,
|
|||||||
case PT_OPEN:
|
case PT_OPEN:
|
||||||
makepol(state, pushval, opaque);
|
makepol(state, pushval, opaque);
|
||||||
|
|
||||||
if (lenstack && (opstack[lenstack - 1] == OP_AND ||
|
while (lenstack && (opstack[lenstack - 1] == OP_AND ||
|
||||||
opstack[lenstack - 1] == OP_NOT))
|
opstack[lenstack - 1] == OP_NOT))
|
||||||
{
|
{
|
||||||
lenstack--;
|
lenstack--;
|
||||||
pushOperator(state, opstack[lenstack]);
|
pushOperator(state, opstack[lenstack]);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user