Commit d47fb03
authored
Fixes a bug with expressions when functions are combined with and/or operations. (#6669)
The function composition change (#6628) converted function from a lexer rule to a parser rule, which meant function arguments became full parser sub-expressions (including conditionalExpression). The ParseTreeEvaluatorListener uses LPAREN/RPAREN tokens on the operatorSymbolStack as barriers to prevent operators from being evaluated inside nested scopes - this is how parenthesesExpression
works correctly. However, the function composition code explicitly skipped LPAREN/RPAREN tokens inside functions, removing this barrier. When a multi-argument function appeared as the right operand of and/or, the AND operator sitting on the stack would fire prematurely when the walker exited the inner conditionalExpression of a function argument, consuming the function's arguments as boolean operands, silently pushing false, and leaving the function with only one argument instead of two.
The fix simply stops skipping LPAREN/RPAREN inside functions, letting them flow through to the normal handling where they act as operator stack barriers.
Signed-off-by: David Venable <dlv@amazon.com>1 parent e2bb830 commit d47fb03
3 files changed
Lines changed: 60 additions & 5 deletions
File tree
- data-prepper-expression/src
- main/java/org/opensearch/dataprepper/expression
- test/java/org/opensearch/dataprepper/expression
Lines changed: 5 additions & 4 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
140 | 140 | | |
141 | 141 | | |
142 | 142 | | |
143 | | - | |
144 | | - | |
145 | | - | |
146 | | - | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
147 | 148 | | |
148 | 149 | | |
149 | 150 | | |
| |||
Lines changed: 2 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
255 | 255 | | |
256 | 256 | | |
257 | 257 | | |
258 | | - | |
| 258 | + | |
| 259 | + | |
259 | 260 | | |
260 | 261 | | |
261 | 262 | | |
| |||
Lines changed: 53 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
529 | 529 | | |
530 | 530 | | |
531 | 531 | | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
| 568 | + | |
| 569 | + | |
| 570 | + | |
| 571 | + | |
| 572 | + | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
| 576 | + | |
| 577 | + | |
| 578 | + | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
532 | 585 | | |
0 commit comments