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

Commit

Permalink
Merge pull request #65 from danez/fix-syntax-error-pos
Browse files Browse the repository at this point in the history
Fixes SyntaxError position with flow optional type
  • Loading branch information
Sebastian McKenzie authored Aug 16, 2016
2 parents 43cdd2f + 64ca55c commit 4af484b
Show file tree
Hide file tree
Showing 6 changed files with 162 additions and 4 deletions.
2 changes: 1 addition & 1 deletion src/parser/expression.js
Original file line number Diff line number Diff line change
Expand Up @@ -558,7 +558,7 @@ pp.parseParenAndDistinguishExpression = function (startPos, startLoc, canBeArrow
if (first) {
first = false;
} else {
this.expect(tt.comma);
this.expect(tt.comma, refNeedsArrowPos.start || null);
if (this.match(tt.parenR) && this.hasPlugin("trailingFunctionCommas")) {
optionalCommaStart = this.state.start;
break;
Expand Down
6 changes: 3 additions & 3 deletions src/parser/util.js
Original file line number Diff line number Diff line change
Expand Up @@ -71,10 +71,10 @@ pp.semicolon = function () {
};

// Expect a token of a given type. If found, consume it, otherwise,
// raise an unexpected token error.
// raise an unexpected token error at given pos.

pp.expect = function (type) {
return this.eat(type) || this.unexpected();
pp.expect = function (type, pos) {
return this.eat(type) || this.unexpected(pos);
};

// Raise an unexpected token error.
Expand Down
1 change: 1 addition & 0 deletions test/fixtures/flow/optional-type/4/actual.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
const f = (...x?) => {}
153 changes: 153 additions & 0 deletions test/fixtures/flow/optional-type/4/expected.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
{
"type": "File",
"start": 0,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 23
}
},
"program": {
"type": "Program",
"start": 0,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 23
}
},
"sourceType": "module",
"body": [
{
"type": "VariableDeclaration",
"start": 0,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 23
}
},
"declarations": [
{
"type": "VariableDeclarator",
"start": 6,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 6
},
"end": {
"line": 1,
"column": 23
}
},
"id": {
"type": "Identifier",
"start": 6,
"end": 7,
"loc": {
"start": {
"line": 1,
"column": 6
},
"end": {
"line": 1,
"column": 7
}
},
"name": "f"
},
"init": {
"type": "ArrowFunctionExpression",
"start": 10,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 10
},
"end": {
"line": 1,
"column": 23
}
},
"id": null,
"generator": false,
"expression": false,
"async": false,
"params": [
{
"type": "RestElement",
"start": 11,
"end": 15,
"loc": {
"start": {
"line": 1,
"column": 11
},
"end": {
"line": 1,
"column": 15
}
},
"argument": {
"type": "Identifier",
"start": 14,
"end": 15,
"loc": {
"start": {
"line": 1,
"column": 14
},
"end": {
"line": 1,
"column": 15
}
},
"name": "x"
},
"optional": true
}
],
"body": {
"type": "BlockStatement",
"start": 21,
"end": 23,
"loc": {
"start": {
"line": 1,
"column": 21
},
"end": {
"line": 1,
"column": 23
}
},
"body": [],
"directives": []
}
}
}
],
"kind": "const"
}
],
"directives": []
}
}
1 change: 1 addition & 0 deletions test/fixtures/flow/optional-type/5/actual.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
a ? b : c ? d : e ? f : g ? h : i ? j : k ? l : m ? n : (o ? p : =);
3 changes: 3 additions & 0 deletions test/fixtures/flow/optional-type/5/options.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"throws": "Unexpected token (1:65)"
}

0 comments on commit 4af484b

Please sign in to comment.