W3C home > Mailing lists > Public > public-script-coord@w3.org > July to September 2011

Re: Strict mode callbacks and setTimeout

From: Mark S. Miller <erights@google.com>
Date: Thu, 7 Jul 2011 00:57:03 +0000
Message-ID: <CABHxS9ioUVybLHfvLntMRJ+S1xF0CTLdL4xOmmGMAATBnGR6zQ@mail.gmail.com>
To: Allen Wirfs-Brock <allen@wirfs-brock.com>, "Mark S. Miller" <erights@google.com>, Boris Zbarsky <bzbarsky@mit.edu>, Luke Hoban <lukeh@microsoft.com>, "es5-discuss@mozilla.org" <es5-discuss@mozilla.org>, public-script-coord@w3.org
On Thu, Jul 7, 2011 at 12:14 AM, Cameron McCormack <cam@mcc.id.au> wrote:

> Allen Wirfs-Brock:
> > Did you mean:
> > (function() {"use strict"; return this}).call(undefined)
> Yeah, I guess I did, thanks.  (I looked quickly at the description of
> Function.prototype.call and figured that the this value given to
> [[Call]] was used unconditionally as the value of `this`, but of course
> the “Entering Function Code” section of the spec does do the strict mode
> check.  I think I assumed `func.call(undefined)` would be different from
> `func()` even in non-strict mode.)
> I also just realised that the checking of the this value that Boris
> quoted will need to be tweaked so that static operations don’t throw.
> Doesn’t setTimeout need to know which window object it is called on, so
> that the right task queue is used?  (I guess that could be encoded into
> the Window.prototype.setTimeout Function object, since there’ll only be
> one window object per setTimeout Function anyway.)

Exactly. It makes a difference. Should

     window1.setTimeout.call(window2, ...)

use window1's or window2's task queue? I think it should use window1's,
i.e., a given setTimeout function should already as-if-lexically capture the
task queue of it birth environment and ignore its this-binding.

> --
> Cameron McCormack ≝ http://mcc.id.au/

Received on Thursday, 7 July 2011 00:57:29 UTC

This archive was generated by hypermail 2.4.0 : Friday, 17 January 2020 17:14:03 UTC