Flow Enums with unknown members support (#12193)
* Flow Enums with unknown members parsing * Updates after rebase Co-authored-by: Nicolò Ribaudo <nicolo.ribaudo@gmail.com>
This commit is contained in:
@@ -3409,10 +3409,13 @@ export default (superClass: Class<Parser>): Class<Parser> =>
|
||||
enumName: string,
|
||||
explicitType: EnumExplicitType,
|
||||
}): {|
|
||||
booleanMembers: Array<N.Node>,
|
||||
numberMembers: Array<N.Node>,
|
||||
stringMembers: Array<N.Node>,
|
||||
defaultedMembers: Array<N.Node>,
|
||||
members: {|
|
||||
booleanMembers: Array<N.Node>,
|
||||
numberMembers: Array<N.Node>,
|
||||
stringMembers: Array<N.Node>,
|
||||
defaultedMembers: Array<N.Node>,
|
||||
|},
|
||||
hasUnknownMembers: boolean,
|
||||
|} {
|
||||
const seenNames = new Set();
|
||||
const members = {
|
||||
@@ -3421,7 +3424,12 @@ export default (superClass: Class<Parser>): Class<Parser> =>
|
||||
stringMembers: [],
|
||||
defaultedMembers: [],
|
||||
};
|
||||
let hasUnknownMembers = false;
|
||||
while (!this.match(tt.braceR)) {
|
||||
if (this.eat(tt.ellipsis)) {
|
||||
hasUnknownMembers = true;
|
||||
break;
|
||||
}
|
||||
const memberNode = this.startNode();
|
||||
const { id, init } = this.flowEnumMemberRaw();
|
||||
const memberName = id.name;
|
||||
@@ -3498,7 +3506,7 @@ export default (superClass: Class<Parser>): Class<Parser> =>
|
||||
this.expect(tt.comma);
|
||||
}
|
||||
}
|
||||
return members;
|
||||
return { members, hasUnknownMembers };
|
||||
}
|
||||
|
||||
flowEnumStringMembers(
|
||||
@@ -3565,7 +3573,11 @@ export default (superClass: Class<Parser>): Class<Parser> =>
|
||||
flowEnumBody(node: N.Node, { enumName, nameLoc }): N.Node {
|
||||
const explicitType = this.flowEnumParseExplicitType({ enumName });
|
||||
this.expect(tt.braceL);
|
||||
const members = this.flowEnumMembers({ enumName, explicitType });
|
||||
const { members, hasUnknownMembers } = this.flowEnumMembers({
|
||||
enumName,
|
||||
explicitType,
|
||||
});
|
||||
node.hasUnknownMembers = hasUnknownMembers;
|
||||
|
||||
switch (explicitType) {
|
||||
case "boolean":
|
||||
|
||||
@@ -48,7 +48,8 @@
|
||||
"value": false
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -19,6 +19,7 @@
|
||||
"type": "EnumBooleanBody",
|
||||
"start":7,"end":35,"loc":{"start":{"line":1,"column":7},"end":{"line":4,"column":1}},
|
||||
"explicitType": false,
|
||||
"hasUnknownMembers": false,
|
||||
"members": [
|
||||
{
|
||||
"type": "EnumBooleanMember",
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumBooleanBody",
|
||||
"start":7,"end":26,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,6 +22,7 @@
|
||||
"type": "EnumBooleanBody",
|
||||
"start":7,"end":27,"loc":{"start":{"line":1,"column":7},"end":{"line":4,"column":1}},
|
||||
"explicitType": false,
|
||||
"hasUnknownMembers": false,
|
||||
"members": [
|
||||
{
|
||||
"type": "EnumBooleanMember",
|
||||
|
||||
@@ -41,7 +41,8 @@
|
||||
"name": "A"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -19,7 +19,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":10,"loc":{"start":{"line":1,"column":7},"end":{"line":1,"column":10}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -19,7 +19,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":10,"end":13,"loc":{"start":{"line":1,"column":10},"end":{"line":2,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -25,7 +25,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":14,"end":16,"loc":{"start":{"line":1,"column":14},"end":{"line":1,"column":16}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
},
|
||||
@@ -44,7 +45,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":40,"end":42,"loc":{"start":{"line":3,"column":22},"end":{"line":3,"column":24}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":29,"loc":{"start":{"line":1,"column":7},"end":{"line":5,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":31,"loc":{"start":{"line":1,"column":7},"end":{"line":4,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":17,"loc":{"start":{"line":1,"column":7},"end":{"line":2,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":32,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -21,7 +21,8 @@
|
||||
"body": {
|
||||
"type": "EnumSymbolBody",
|
||||
"start":7,"end":29,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumBooleanBody",
|
||||
"start":7,"end":30,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":29,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumBooleanBody",
|
||||
"start":7,"end":33,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumNumberBody",
|
||||
"start":7,"end":32,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -42,7 +42,8 @@
|
||||
"name": "bar"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -29,7 +29,8 @@
|
||||
"name": "A"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -56,7 +56,8 @@
|
||||
"value": 2
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -19,6 +19,7 @@
|
||||
"type": "EnumNumberBody",
|
||||
"start":7,"end":28,"loc":{"start":{"line":1,"column":7},"end":{"line":4,"column":1}},
|
||||
"explicitType": false,
|
||||
"hasUnknownMembers": false,
|
||||
"members": [
|
||||
{
|
||||
"type": "EnumNumberMember",
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumNumberBody",
|
||||
"start":7,"end":25,"loc":{"start":{"line":1,"column":7},"end":{"line":3,"column":1}},
|
||||
"explicitType": true,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -22,6 +22,7 @@
|
||||
"type": "EnumNumberBody",
|
||||
"start":7,"end":24,"loc":{"start":{"line":1,"column":7},"end":{"line":4,"column":1}},
|
||||
"explicitType": false,
|
||||
"hasUnknownMembers": false,
|
||||
"members": [
|
||||
{
|
||||
"type": "EnumNumberMember",
|
||||
|
||||
@@ -22,7 +22,8 @@
|
||||
"type": "EnumStringBody",
|
||||
"start":11,"end":14,"loc":{"start":{"line":1,"column":11},"end":{"line":2,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": []
|
||||
"members": [],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -38,7 +38,8 @@
|
||||
"name": "B"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -56,7 +56,8 @@
|
||||
"value": "b"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -38,7 +38,8 @@
|
||||
"name": "B"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -56,7 +56,8 @@
|
||||
"value": "b"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -41,7 +41,8 @@
|
||||
"name": "C"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -59,7 +59,8 @@
|
||||
"value": "c"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
@@ -37,7 +37,8 @@
|
||||
"name": "B"
|
||||
}
|
||||
}
|
||||
]
|
||||
],
|
||||
"hasUnknownMembers": false
|
||||
}
|
||||
}
|
||||
],
|
||||
|
||||
3
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members-invalid/input.js
vendored
Normal file
3
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members-invalid/input.js
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
enum E {
|
||||
...,
|
||||
}
|
||||
11
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members-invalid/options.json
vendored
Normal file
11
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members-invalid/options.json
vendored
Normal file
@@ -0,0 +1,11 @@
|
||||
{
|
||||
"plugins": [
|
||||
[
|
||||
"flow",
|
||||
{
|
||||
"enums": true
|
||||
}
|
||||
]
|
||||
],
|
||||
"throws": "Unexpected token, expected \"}\" (2:5)"
|
||||
}
|
||||
5
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members/input.js
vendored
Normal file
5
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members/input.js
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
enum E {
|
||||
A,
|
||||
B,
|
||||
...
|
||||
}
|
||||
48
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members/output.json
vendored
Normal file
48
packages/babel-parser/test/fixtures/flow/enum-declaration/unknown-members/output.json
vendored
Normal file
@@ -0,0 +1,48 @@
|
||||
{
|
||||
"type": "File",
|
||||
"start":0,"end":26,"loc":{"start":{"line":1,"column":0},"end":{"line":5,"column":1}},
|
||||
"program": {
|
||||
"type": "Program",
|
||||
"start":0,"end":26,"loc":{"start":{"line":1,"column":0},"end":{"line":5,"column":1}},
|
||||
"sourceType": "script",
|
||||
"interpreter": null,
|
||||
"body": [
|
||||
{
|
||||
"type": "EnumDeclaration",
|
||||
"start":0,"end":26,"loc":{"start":{"line":1,"column":0},"end":{"line":5,"column":1}},
|
||||
"id": {
|
||||
"type": "Identifier",
|
||||
"start":5,"end":6,"loc":{"start":{"line":1,"column":5},"end":{"line":1,"column":6},"identifierName":"E"},
|
||||
"name": "E"
|
||||
},
|
||||
"body": {
|
||||
"type": "EnumStringBody",
|
||||
"start":7,"end":26,"loc":{"start":{"line":1,"column":7},"end":{"line":5,"column":1}},
|
||||
"explicitType": false,
|
||||
"members": [
|
||||
{
|
||||
"type": "EnumDefaultedMember",
|
||||
"start":11,"end":12,"loc":{"start":{"line":2,"column":2},"end":{"line":2,"column":3}},
|
||||
"id": {
|
||||
"type": "Identifier",
|
||||
"start":11,"end":12,"loc":{"start":{"line":2,"column":2},"end":{"line":2,"column":3},"identifierName":"A"},
|
||||
"name": "A"
|
||||
}
|
||||
},
|
||||
{
|
||||
"type": "EnumDefaultedMember",
|
||||
"start":16,"end":17,"loc":{"start":{"line":3,"column":2},"end":{"line":3,"column":3}},
|
||||
"id": {
|
||||
"type": "Identifier",
|
||||
"start":16,"end":17,"loc":{"start":{"line":3,"column":2},"end":{"line":3,"column":3},"identifierName":"B"},
|
||||
"name": "B"
|
||||
}
|
||||
}
|
||||
],
|
||||
"hasUnknownMembers": true
|
||||
}
|
||||
}
|
||||
],
|
||||
"directives": []
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user