isDynamicName skips parentheses for element access

Neither `x[0]` nor `x[(0)]` should be dynamic names. Previously, the
latter was because `isDynamicName` didn't skip parentheses.

Since the binder treats dynamic names in property assignments as
assignment declarations, this incorrectly tried to create a binding for
expressions like `x[(0)] = 1`.

This caused an assert because `x[(0)]` would not take the dynamic name
code path during binding (`hasDynamicName` returned false), but the
normal code path for static names.
This commit is contained in:
Nathan Shively-Sanders
2020-06-11 09:08:51 -07:00
parent ffa35d3272
commit a64166de14
4 changed files with 31 additions and 1 deletions

View File

@@ -0,0 +1,8 @@
// @allowJs: true
// @checkJs: true
// @noEmit: true
// @Filename: bug38934.js
var x = {};
// should not crash and also should not result in a property '0' on x.
x[(0)] = 1;