Skip to content

Commit

Permalink
Fix parsing typescript function types with destructuring (#9035)
Browse files Browse the repository at this point in the history
* Fix parsing typescript function types with destructuring

* Use integer instead of actual stack
  • Loading branch information
danez committed Nov 19, 2018
1 parent c11cdcb commit a2afb97
Show file tree
Hide file tree
Showing 4 changed files with 243 additions and 4 deletions.
28 changes: 25 additions & 3 deletions packages/babel-parser/src/plugins/typescript.js
Expand Up @@ -314,13 +314,19 @@ export default (superClass: Class<Parser>): Class<Parser> =>
}

tsParseBindingListForSignature(): $ReadOnlyArray<
N.Identifier | N.RestElement,
N.Identifier | N.RestElement | N.ObjectPattern,
> {
return this.parseBindingList(tt.parenR).map(pattern => {
if (pattern.type !== "Identifier" && pattern.type !== "RestElement") {
if (
pattern.type !== "Identifier" &&
pattern.type !== "RestElement" &&
pattern.type !== "ObjectPattern"
) {
throw this.unexpected(
pattern.start,
"Name in a signature must be an Identifier.",
`Name in a signature must be an Identifier or ObjectPattern, instead got ${
pattern.type
}`,
);
}
return pattern;
Expand Down Expand Up @@ -747,6 +753,22 @@ export default (superClass: Class<Parser>): Class<Parser> =>
this.next();
return true;
}

if (this.match(tt.braceL)) {
let braceStackCounter = 1;
this.next();

while (braceStackCounter > 0) {
if (this.match(tt.braceL)) {
++braceStackCounter;
} else if (this.match(tt.braceR)) {
--braceStackCounter;
}
this.next();
}
return true;
}

return false;
}

Expand Down
2 changes: 1 addition & 1 deletion packages/babel-parser/src/types.js
Expand Up @@ -1037,7 +1037,7 @@ export type TsSignatureDeclaration =

export type TsSignatureDeclarationOrIndexSignatureBase = NodeBase & {
// Not using TypeScript's "ParameterDeclaration" here, since it's inconsistent with regular functions.
parameters: $ReadOnlyArray<Identifier | RestElement>,
parameters: $ReadOnlyArray<Identifier | RestElement | ObjectPattern>,
typeAnnotation: ?TsTypeAnnotation,
};

Expand Down
@@ -0,0 +1 @@
type MyType = ({ theme }: any) => any
@@ -0,0 +1,216 @@
{
"type": "File",
"start": 0,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 37
}
},
"program": {
"type": "Program",
"start": 0,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 37
}
},
"sourceType": "module",
"interpreter": null,
"body": [
{
"type": "TSTypeAliasDeclaration",
"start": 0,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 37
}
},
"id": {
"type": "Identifier",
"start": 5,
"end": 11,
"loc": {
"start": {
"line": 1,
"column": 5
},
"end": {
"line": 1,
"column": 11
},
"identifierName": "MyType"
},
"name": "MyType"
},
"typeAnnotation": {
"type": "TSFunctionType",
"start": 14,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 14
},
"end": {
"line": 1,
"column": 37
}
},
"parameters": [
{
"type": "ObjectPattern",
"start": 15,
"end": 29,
"loc": {
"start": {
"line": 1,
"column": 15
},
"end": {
"line": 1,
"column": 29
}
},
"properties": [
{
"type": "ObjectProperty",
"start": 17,
"end": 22,
"loc": {
"start": {
"line": 1,
"column": 17
},
"end": {
"line": 1,
"column": 22
}
},
"method": false,
"key": {
"type": "Identifier",
"start": 17,
"end": 22,
"loc": {
"start": {
"line": 1,
"column": 17
},
"end": {
"line": 1,
"column": 22
},
"identifierName": "theme"
},
"name": "theme"
},
"computed": false,
"shorthand": true,
"value": {
"type": "Identifier",
"start": 17,
"end": 22,
"loc": {
"start": {
"line": 1,
"column": 17
},
"end": {
"line": 1,
"column": 22
},
"identifierName": "theme"
},
"name": "theme"
},
"extra": {
"shorthand": true
}
}
],
"typeAnnotation": {
"type": "TSTypeAnnotation",
"start": 24,
"end": 29,
"loc": {
"start": {
"line": 1,
"column": 24
},
"end": {
"line": 1,
"column": 29
}
},
"typeAnnotation": {
"type": "TSAnyKeyword",
"start": 26,
"end": 29,
"loc": {
"start": {
"line": 1,
"column": 26
},
"end": {
"line": 1,
"column": 29
}
}
}
}
}
],
"typeAnnotation": {
"type": "TSTypeAnnotation",
"start": 31,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 31
},
"end": {
"line": 1,
"column": 37
}
},
"typeAnnotation": {
"type": "TSAnyKeyword",
"start": 34,
"end": 37,
"loc": {
"start": {
"line": 1,
"column": 34
},
"end": {
"line": 1,
"column": 37
}
}
}
}
}
}
],
"directives": []
}
}

0 comments on commit a2afb97

Please sign in to comment.