+public-script-coord

On Sep 27, 2009, at 4:19 PM, David-Sarah Hopwood wrote:

Maciej Stachowiak wrote:
On Sep 27, 2009, at 11:14 AM, Brendan Eich wrote:
On Sep 27, 2009, at 10:41 AM, David-Sarah Hopwood wrote:

That can already be done in ES5. As I've previously suggested:

function Date(yearOrValue, month, date, hours, minutes, seconds, ms) {
 "use strict";
 if (this === undefined) {
   return TimeToString(CurrentTime());
 }
 // constructor behaviour
 ...
}

Of course, a variation on "the idiom".

This is similar to what many implementations do too, rather than the
implementation providing analogues of [[Call]] and [[Construct]]
internal method on a non-function Date object. It works for Boolean,
Number, String, and RegExp too.

But it is just a bit unsightly!

Will this do the right thing if you explicitly bind Date to a "this"
value, for example, by calling it as window.Date(), or using call,
apply, or function.bind, or by storing Date as the property of another
random object?

Now that I think about it, probably not (it will attempt to set the
[[Class]] of 'this' to "Date", which is unsafe). But the problem here
isn't introduced by the fact that [[Call]] and [[Construct]] have
different behaviour: none of the other built-in constructors can be
safely expressed in ES5 for the same reason, regardless of their
[[Call]] behaviour.

I believe the built-in constructors could be implemented correctly by ignoring their "this" parameter and making a fresh object of the appropriate type, rather than by modifying the [[Class]] of a presumed "this" passed as part of construction. For any that have identical [[Call]] and [[Construct]] behavior, it would then be fine to write it as a function - either way it produces a new object and ignores whatever may have been passed for "this". This is true for Array for instance. (Object call and construct also look like they have the same behavior, though written in two different ways for some reason.)

Regards,
Maciej




_______________________________________________
es-discuss mailing list
es-discuss@mozilla.org
https://mail.mozilla.org/listinfo/es-discuss

Reply via email to