Skip to content
This repository has been archived by the owner on May 19, 2018. It is now read-only.

Commit

Permalink
pipelineOperator proposal
Browse files Browse the repository at this point in the history
  • Loading branch information
hzoo committed Sep 28, 2017
1 parent 508cb70 commit 1188446
Show file tree
Hide file tree
Showing 10 changed files with 127 additions and 3 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,7 @@ require("babylon").parse("code", {
| `bigInt` ([proposal](https://github.com/tc39/proposal-bigint)) | `100n` |
| `optionalCatchBinding` ([proposal](https://github.com/babel/proposals/issues/7)) | `try {throw 0;} catch{do();}` |
| `throwExpressions` ([proposal](https://github.com/babel/proposals/issues/23)) | `() => throw new Error("")` |
| `pipelineOperator` ([proposal](https://github.com/babel/proposals/issues/29)) | `a |> b` |

### FAQ

Expand Down
1 change: 1 addition & 0 deletions ast/spec.md
Original file line number Diff line number Diff line change
Expand Up @@ -790,6 +790,7 @@ enum BinaryOperator {
| "+" | "-" | "*" | "/" | "%"
| "|" | "^" | "&" | "in"
| "instanceof"
| "|>"
}
```

Expand Down
6 changes: 6 additions & 0 deletions src/parser/expression.js
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,12 @@ export default class ExpressionParser extends LValParser {

const startPos = this.state.start;
const startLoc = this.state.startLoc;

if (node.operator === "|>") {
// Support syntax such as 10 |> x => x + 1
this.state.potentialArrowAt = startPos;
}

node.right = this.parseExprOp(
this.parseMaybeUnary(),
startPos,
Expand Down
12 changes: 10 additions & 2 deletions src/tokenizer/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -411,9 +411,17 @@ export default class Tokenizer extends LocationParser {
const next = this.input.charCodeAt(this.state.pos + 1);
if (next === code)
return this.finishOp(code === 124 ? tt.logicalOR : tt.logicalAND, 2);
if (code === 124) {
// '|>'
if (next === 62) {
this.expectPlugin("pipelineOperator");
return this.finishOp(tt.pipeline, 2);
} else if (next === 125 && this.hasPlugin("flow")) {
// '|}'
return this.finishOp(tt.braceBarR, 2);
}
}
if (next === 61) return this.finishOp(tt.assign, 2);
if (code === 124 && next === 125 && this.hasPlugin("flow"))
return this.finishOp(tt.braceBarR, 2);
return this.finishOp(code === 124 ? tt.bitwiseOR : tt.bitwiseAND, 1);
}

Expand Down
3 changes: 2 additions & 1 deletion src/tokenizer/types.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ export class TokenType {
this.isAssign = !!conf.isAssign;
this.prefix = !!conf.prefix;
this.postfix = !!conf.postfix;
this.binop = conf.binop || null;
this.binop = conf.binop === 0 ? 0 : conf.binop || null;
this.updateContext = null;
}
}
Expand Down Expand Up @@ -131,6 +131,7 @@ export const types: { [name: string]: TokenType } = {
incDec: new TokenType("++/--", { prefix, postfix, startsExpr }),
bang: new TokenType("!", { beforeExpr, prefix, startsExpr }),
tilde: new TokenType("~", { beforeExpr, prefix, startsExpr }),
pipeline: new BinopTokenType("|>", 0),
logicalOR: new BinopTokenType("||", 1),
logicalAND: new BinopTokenType("&&", 2),
bitwiseOR: new BinopTokenType("|", 3),
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
a |> b
99 changes: 99 additions & 0 deletions test/fixtures/experimental/pipeline-operator/base/expected.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
{
"type": "File",
"start": 0,
"end": 6,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 6
}
},
"program": {
"type": "Program",
"start": 0,
"end": 6,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 6
}
},
"sourceType": "script",
"body": [
{
"type": "ExpressionStatement",
"start": 0,
"end": 6,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 6
}
},
"expression": {
"type": "BinaryExpression",
"start": 0,
"end": 6,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 6
}
},
"left": {
"type": "Identifier",
"start": 0,
"end": 1,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 1
},
"identifierName": "a"
},
"name": "a"
},
"operator": "|>",
"right": {
"type": "Identifier",
"start": 5,
"end": 6,
"loc": {
"start": {
"line": 1,
"column": 5
},
"end": {
"line": 1,
"column": 6
},
"identifierName": "b"
},
"name": "b"
}
}
}
],
"directives": []
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"plugins": ["pipelineOperator"]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
a |> b
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"throws": "This experimental syntax requires enabling the parser plugin: 'pipelineOperator' (1:2)"
}

0 comments on commit 1188446

Please sign in to comment.