Skip to content

Commit

Permalink
Merge pull request #1677 from DanielXMoore/binary-op-unary-arg
Browse files Browse the repository at this point in the history
Fix immediately called `(op)` in pipeline context
  • Loading branch information
edemaine authored Jan 5, 2025
2 parents a9fd414 + 66d8440 commit aa8b8c1
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 5 deletions.
16 changes: 11 additions & 5 deletions source/parser/lib.civet
Original file line number Diff line number Diff line change
Expand Up @@ -562,12 +562,18 @@ function processCallMemberExpression(node: CallExpression | MemberExpression): A
(isComma(arg) as ASTLeaf).token = `)${op.token}(`
commaCount++
// Don't mess with (+)()
if args.length
children.splice 0, 2,
commaCount ?
if args#
if commaCount
children.splice 0, 2,
type: "ParenthesizedExpression"
children: ["(", ...call.children, ")"]
: { ...call, type: "ParenthesizedExpression" }
children: ["(", call.children, ")"]
expression: call.children
else // already parenthesized by argument parens
middle := call.children[<..<]
children.splice 0, 2,
type: "ParenthesizedExpression"
expression: middle
children: [ call.children.0, middle, call.children.-1 ]
// If nothing left to this CallExpression, remove the wrapper
if children# is 1
return children[0]
Expand Down
8 changes: 8 additions & 0 deletions test/function-block-shorthand.civet
Original file line number Diff line number Diff line change
Expand Up @@ -920,6 +920,14 @@ describe "(op) shorthand", ->
(1)
"""

testCase """
apply binary op with one argument in pipeline
---
foo |> (+) x
---
(x)(foo)
"""

testCase """
apply binary op with no arguments
---
Expand Down

0 comments on commit aa8b8c1

Please sign in to comment.