How to escape implicit 'with (this)' of a method body
Brendan Eich
brendan at mozilla.org
Mon Jul 28 22:19:58 PDT 2008
On Jul 28, 2008, at 10:05 PM, Jon Zeppieri wrote:
> Isn't the 'with' statement in the original example significant? In
> the general case, assuming that you don't know what properties 'this'
> has (as it may have dynamic properties in addition to the fixtures
> determined by its class), you have no way of knowing whether 'global'
> or 'window' refers to the global object or to some arbitrary property
> of 'this.'
The original code used "without (this)", not "with", which I took to
mean "avoid instance properties shadowing globals". If you read the
original as "with", then there is no such problem. But if you
construct a problematic case using 'with' and dynamic properties,
then I concede that 'global' could be shadowed. This is a reason to
avoid 'with'. In the ES4 proposals last sent out, you could always
use __ES4__::global if you really wanted to avoid conflicts -- unless
someone perversely added '__ES4__' as a dynamic instance property.
There's no solution to this problem other than reserving at least one
name, and we can't do that compatibly. We could reserve __ES4__ in
version-selected ES4 mode, but that seems unnecessary.
/be
More information about the Es4-discuss
mailing list