Use the canonical value of undefined
in generated JavaScript code.
#82
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.
Using
undefined
in generated code is fragile as it is global mutablevariable, not a constant. As a consequence a buggy equality test such
as
if (foo = undefined) { ... }
or similar in generated code or anythird-party code can inadvertently break the entire runtime. Such bugs
can be difficult to localise.
To make the runtime more robust this patch introduces a slight change
to the JavaScript code generator such that the emitted code uses the
canonical value of
undefined
rather than the variable nameundefined
. The canonical value can be obtain via the odd expression(void 0)
. Sincevoid
is a keyword and0
is a numeric literal itis not possible for user-code to override their semantics, hence the
expression is resilient against mutations such as monkey-patching.