Fix getExpandoSymbol for already-expando symbols #36457
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
getExpandoSymbol
is intended to get the symbol of the expando in a declaration likeHowever, when this occurs in a
module.exports
assignment, alias resolution already jumps to the exported symbol -- in this case the expando symbol:getExpandoSymbol
is then called onclass { }
instead ofmodule.exports = class { }
.Previously,
getExpandoSymbol
would incorrectly treatclass { }
the same as the export assignment and get the expando ... from the expandoitself. This resulted in merging the expando with itself, which causes bogus errors in webpack and could cause other problems.
Now
getExpandoSymbol
checks that the declaration is not already an expando.Fixes #34809