fix: do not push new token context when function is following dot/questionDot (#11388)
* fix: do not push new token context when function is following dot/questionDot * more cautiously poping context
This commit is contained in:
parent
fbcb251d61
commit
8b976b0670
@ -2125,17 +2125,15 @@ export default class ExpressionParser extends LValParser {
|
||||
} else if (this.state.type.keyword) {
|
||||
name = this.state.type.keyword;
|
||||
|
||||
// `class` and `function` keywords push new context into this.context.
|
||||
// `class` and `function` keywords push function-type token context into this.context.
|
||||
// But there is no chance to pop the context if the keyword is consumed
|
||||
// as an identifier such as a property name.
|
||||
// If the previous token is a dot, this does not apply because the
|
||||
// context-managing code already ignored the keyword
|
||||
const context = this.state.context;
|
||||
if (
|
||||
(name === "class" || name === "function") &&
|
||||
(this.state.lastTokEnd !== this.state.lastTokStart + 1 ||
|
||||
this.input.charCodeAt(this.state.lastTokStart) !== charCodes.dot)
|
||||
context[context.length - 1].token === "function"
|
||||
) {
|
||||
this.state.context.pop();
|
||||
context.pop();
|
||||
}
|
||||
} else {
|
||||
throw this.unexpected();
|
||||
|
||||
@ -101,7 +101,10 @@ tt.incDec.updateContext = function() {
|
||||
};
|
||||
|
||||
tt._function.updateContext = tt._class.updateContext = function(prevType) {
|
||||
if (
|
||||
if (prevType === tt.dot || prevType === tt.questionDot) {
|
||||
// when function/class follows dot/questionDot, it is part of
|
||||
// (optional)MemberExpression, then we don't need to push new token context
|
||||
} else if (
|
||||
prevType.beforeExpr &&
|
||||
prevType !== tt.semi &&
|
||||
prevType !== tt._else &&
|
||||
|
||||
1
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/input.js
vendored
Normal file
1
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/input.js
vendored
Normal file
@ -0,0 +1 @@
|
||||
<div>{(this?.class, this.class, this?.function, this.function)}</div>
|
||||
3
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/options.json
vendored
Normal file
3
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/options.json
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
{
|
||||
"plugins": ["jsx", "flow"]
|
||||
}
|
||||
115
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/output.json
vendored
Normal file
115
packages/babel-parser/test/fixtures/jsx/regression/issue-11387/output.json
vendored
Normal file
@ -0,0 +1,115 @@
|
||||
{
|
||||
"type": "File",
|
||||
"start":0,"end":69,"loc":{"start":{"line":1,"column":0},"end":{"line":1,"column":69}},
|
||||
"program": {
|
||||
"type": "Program",
|
||||
"start":0,"end":69,"loc":{"start":{"line":1,"column":0},"end":{"line":1,"column":69}},
|
||||
"sourceType": "script",
|
||||
"interpreter": null,
|
||||
"body": [
|
||||
{
|
||||
"type": "ExpressionStatement",
|
||||
"start":0,"end":69,"loc":{"start":{"line":1,"column":0},"end":{"line":1,"column":69}},
|
||||
"expression": {
|
||||
"type": "JSXElement",
|
||||
"start":0,"end":69,"loc":{"start":{"line":1,"column":0},"end":{"line":1,"column":69}},
|
||||
"openingElement": {
|
||||
"type": "JSXOpeningElement",
|
||||
"start":0,"end":5,"loc":{"start":{"line":1,"column":0},"end":{"line":1,"column":5}},
|
||||
"name": {
|
||||
"type": "JSXIdentifier",
|
||||
"start":1,"end":4,"loc":{"start":{"line":1,"column":1},"end":{"line":1,"column":4}},
|
||||
"name": "div"
|
||||
},
|
||||
"attributes": [],
|
||||
"selfClosing": false
|
||||
},
|
||||
"closingElement": {
|
||||
"type": "JSXClosingElement",
|
||||
"start":63,"end":69,"loc":{"start":{"line":1,"column":63},"end":{"line":1,"column":69}},
|
||||
"name": {
|
||||
"type": "JSXIdentifier",
|
||||
"start":65,"end":68,"loc":{"start":{"line":1,"column":65},"end":{"line":1,"column":68}},
|
||||
"name": "div"
|
||||
}
|
||||
},
|
||||
"children": [
|
||||
{
|
||||
"type": "JSXExpressionContainer",
|
||||
"start":5,"end":63,"loc":{"start":{"line":1,"column":5},"end":{"line":1,"column":63}},
|
||||
"expression": {
|
||||
"type": "SequenceExpression",
|
||||
"start":7,"end":61,"loc":{"start":{"line":1,"column":7},"end":{"line":1,"column":61}},
|
||||
"expressions": [
|
||||
{
|
||||
"type": "OptionalMemberExpression",
|
||||
"start":7,"end":18,"loc":{"start":{"line":1,"column":7},"end":{"line":1,"column":18}},
|
||||
"object": {
|
||||
"type": "ThisExpression",
|
||||
"start":7,"end":11,"loc":{"start":{"line":1,"column":7},"end":{"line":1,"column":11}}
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"start":13,"end":18,"loc":{"start":{"line":1,"column":13},"end":{"line":1,"column":18},"identifierName":"class"},
|
||||
"name": "class"
|
||||
},
|
||||
"computed": false,
|
||||
"optional": true
|
||||
},
|
||||
{
|
||||
"type": "MemberExpression",
|
||||
"start":20,"end":30,"loc":{"start":{"line":1,"column":20},"end":{"line":1,"column":30}},
|
||||
"object": {
|
||||
"type": "ThisExpression",
|
||||
"start":20,"end":24,"loc":{"start":{"line":1,"column":20},"end":{"line":1,"column":24}}
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"start":25,"end":30,"loc":{"start":{"line":1,"column":25},"end":{"line":1,"column":30},"identifierName":"class"},
|
||||
"name": "class"
|
||||
},
|
||||
"computed": false
|
||||
},
|
||||
{
|
||||
"type": "OptionalMemberExpression",
|
||||
"start":32,"end":46,"loc":{"start":{"line":1,"column":32},"end":{"line":1,"column":46}},
|
||||
"object": {
|
||||
"type": "ThisExpression",
|
||||
"start":32,"end":36,"loc":{"start":{"line":1,"column":32},"end":{"line":1,"column":36}}
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"start":38,"end":46,"loc":{"start":{"line":1,"column":38},"end":{"line":1,"column":46},"identifierName":"function"},
|
||||
"name": "function"
|
||||
},
|
||||
"computed": false,
|
||||
"optional": true
|
||||
},
|
||||
{
|
||||
"type": "MemberExpression",
|
||||
"start":48,"end":61,"loc":{"start":{"line":1,"column":48},"end":{"line":1,"column":61}},
|
||||
"object": {
|
||||
"type": "ThisExpression",
|
||||
"start":48,"end":52,"loc":{"start":{"line":1,"column":48},"end":{"line":1,"column":52}}
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"start":53,"end":61,"loc":{"start":{"line":1,"column":53},"end":{"line":1,"column":61},"identifierName":"function"},
|
||||
"name": "function"
|
||||
},
|
||||
"computed": false
|
||||
}
|
||||
],
|
||||
"extra": {
|
||||
"parenthesized": true,
|
||||
"parenStart": 6
|
||||
}
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
],
|
||||
"directives": []
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user