Skip to content

Commit

Permalink
Allow variable and function with the same name in static blocks (#14344)
Browse files Browse the repository at this point in the history
* solution to [Bug]: Parser throws when var declaration and function declaration in class static block #14257

* removed SCOPE_FUNCTION addition in statement.js (babel-parser)

* Update packages/babel-parser/src/util/scope.js

Co-authored-by: Hu谩ng J霉nli脿ng <jlhwung@gmail.com>

* Undo unrelated changes

* test case in new subdir

* import typeof.js

* import typeof.js

* import typeof.js in babel-runtime

* import correct typeof.js in corejs2 and 3 in esm

* removed 2 unneeded tests from es2015

Co-authored-by: Hu谩ng J霉nli脿ng <jlhwung@gmail.com>
Co-authored-by: Nicol貌 Ribaudo <nicolo.ribaudo@gmail.com>
  • Loading branch information
3 people committed Mar 10, 2022
1 parent 0f62c58 commit bae5027
Show file tree
Hide file tree
Showing 3 changed files with 77 additions and 1 deletion.
2 changes: 1 addition & 1 deletion packages/babel-parser/src/util/scope.js
Expand Up @@ -103,7 +103,7 @@ export default class ScopeHandler<IScope: Scope = Scope> {
// > treated like var declarations rather than like lexical declarations.
treatFunctionsAsVarInScope(scope: IScope): boolean {
return !!(
scope.flags & SCOPE_FUNCTION ||
scope.flags & (SCOPE_FUNCTION | SCOPE_STATIC_BLOCK) ||
(!this.parser.inModule && scope.flags & SCOPE_PROGRAM)
);
}
Expand Down
@@ -0,0 +1,6 @@
class X {
static {
var x;
function x() {}
}
}
@@ -0,0 +1,70 @@
{
"type": "File",
"start":0,"end":65,"loc":{"start":{"line":1,"column":0,"index":0},"end":{"line":6,"column":1,"index":65}},
"program": {
"type": "Program",
"start":0,"end":65,"loc":{"start":{"line":1,"column":0,"index":0},"end":{"line":6,"column":1,"index":65}},
"sourceType": "script",
"interpreter": null,
"body": [
{
"type": "ClassDeclaration",
"start":0,"end":65,"loc":{"start":{"line":1,"column":0,"index":0},"end":{"line":6,"column":1,"index":65}},
"id": {
"type": "Identifier",
"start":6,"end":7,"loc":{"start":{"line":1,"column":6,"index":6},"end":{"line":1,"column":7,"index":7},"identifierName":"X"},
"name": "X"
},
"superClass": null,
"body": {
"type": "ClassBody",
"start":8,"end":65,"loc":{"start":{"line":1,"column":8,"index":8},"end":{"line":6,"column":1,"index":65}},
"body": [
{
"type": "StaticBlock",
"start":14,"end":63,"loc":{"start":{"line":2,"column":4,"index":14},"end":{"line":5,"column":5,"index":63}},
"body": [
{
"type": "VariableDeclaration",
"start":29,"end":35,"loc":{"start":{"line":3,"column":6,"index":29},"end":{"line":3,"column":12,"index":35}},
"declarations": [
{
"type": "VariableDeclarator",
"start":33,"end":34,"loc":{"start":{"line":3,"column":10,"index":33},"end":{"line":3,"column":11,"index":34}},
"id": {
"type": "Identifier",
"start":33,"end":34,"loc":{"start":{"line":3,"column":10,"index":33},"end":{"line":3,"column":11,"index":34},"identifierName":"x"},
"name": "x"
},
"init": null
}
],
"kind": "var"
},
{
"type": "FunctionDeclaration",
"start":42,"end":57,"loc":{"start":{"line":4,"column":6,"index":42},"end":{"line":4,"column":21,"index":57}},
"id": {
"type": "Identifier",
"start":51,"end":52,"loc":{"start":{"line":4,"column":15,"index":51},"end":{"line":4,"column":16,"index":52},"identifierName":"x"},
"name": "x"
},
"generator": false,
"async": false,
"params": [],
"body": {
"type": "BlockStatement",
"start":55,"end":57,"loc":{"start":{"line":4,"column":19,"index":55},"end":{"line":4,"column":21,"index":57}},
"body": [],
"directives": []
}
}
]
}
]
}
}
],
"directives": []
}
}

0 comments on commit bae5027

Please sign in to comment.