"use subset" introductory material
brendan at mozilla.org
Wed Jul 2 19:01:12 PDT 2008
On Jul 1, 2008, at 10:55 AM, Mark S. Miller wrote:
> If the ES4 and ES3.1 folks can agree on their respective meanings of
> the subset named "strict", such that
> * ES3.1 < ES4
> * ES3.1 strict < ES3.1
> * ES4 strict < ES4
> * ES3.1 strict < ES4 strict
> then we'd only need the two subset names needed for these
> distinctions. Even then, making the syntax change from
> "use strict";
> "use subset strict";
> still seems like a good idea to me.
I'm not in favor of uniformity over usability, especially if for
whatever reason we do not add subsets to future standards. 'use
strict' is short and sweet, familiar from Perl and other languages,
and IMHO much better than the pedantic (sorry, but it fits :-P) 'use
If we do standardize more subsets, we can cross the longer bridge then.
This is a small point, but it highlights tension between usability
("read" as well as "write", I claim) and "completeness" (for want of
a better word). Anyway the ES4 pragma syntax prefers one-word terms,
although there have been ad-hoc two-word forms.
> At the last F2F, Lars and Brendan
> raised the possibility that they might like to define stricter modes
> in successors of ES4. The notion of named subsets would seem to
> accommodate that. Brendan & Lars, in the absence of named subsets, how
> would you introduce such stricter modes in that future? What would you
Mainly what I recall we talked about at that meeting was simply the
idea that (ESn+1 strict could be < ESn strict) -- that one could make
strict mode stricter over time. Adding 'use stricter' was not a
serious proposal, IIRC.
I recall also we did not want strict mode to be part of the MIME-
typed version parameter, or the version to be selectable by a pragma.
So the only issue was upgrading from ESn to ESn+1 and facing a
stricter strict mode. Standard mode would be highly backward
compatible, with unpredictable and slow obsolescence leading to some
amount of deadwood shedding over time -- maybe.
> Of the above desired subset relationships, the problematic one is the
> last bullet above.
* ES3.1 strict < ES4 strict
> The outstanding disagreements are variable arity
> strict functions and "with". Hopefully we can resolve these in Oslo.
> In the meantime, to avoid stepping on each other's toes, we've renamed
> "ES3.1 strict" to "cautious". That's all that's going on. I'm
> surprised there's such a fuss.
Probably you are right, and there's too much fuss. On the other hand,
we now have a straw "cautious" mode to argue about. It would be
better to get agreement on strict before expending the effort and
seeming to up the "subset violation" ante (not entirely a matter of
perception; every documented and jargonized change tends to take on a
life of its own, and fight for survival).
>> That's my point -- profiled standards may pretend that
>> implementations can pick and choose among profiles to support, but on
>> the web's winner-take-all network effects force every implementation
>> to agree on the full standard.
> Aren't you, Crock, and the rest of us vigorously agreeing?
I am pretty sure we agree on a lot -- more than you might think ;-).
But let's be clear on what I am arguing against: multiple subsets
taking precious standards-making bandwidth, adding to the complexity
(even temporarily) of the work within ES3.1 and ES4, and of course
Yes, subsets are useful -- so useful there are a great many out
there. No, we should not try to standardize them all, or invent
overlong syntax with which to select them, if we are only talking
about strict mode.
>> Users choosing subsets from full
>> implementations do not simplify the implementation space,
> Agreed. That's not the point.
But that's my point, one of them: the specs are in large part for the
benefit of implementors, to make interoperation a more likely
outcome. Since web browser implementations have to handle the whole
language (and then some: quirks and deprecated features may remain
for a long while), the spec should not overreach for subsets at the
expense of clarity, compatibility, and completeness.
Complexity due to unnecessary subset additions, or mooting, or future-
proofing, is therefore not welcome, all else equal -- IMHO.
>> and too
>> many subsets make a mess of the spec and its implementation.
> Agreed. Let's continue to try to reconcile "strict" and "cautious".
> And let's avoid adding any more choices to the menu in the ES3.1/ES4
I agree completely -- good to read this.
>> What users -- as opposed to es3.x-discuss participants who may have
>> different and seemingly contradictory goals -- have asked for these
> To my ears, I've been quite amazed at how convergent our thinking has
> been on these matters. What disagreements and contradictions do you
> see among the es3.x-discuss participants?
I was quoting Allen there. He wrote (two messages up on this thread):
"This is an interesting exercise because I'm trying to find a path
that is tolerable for a number of different individuals who seem to
have different and sometimes seemingly contradictory goals: ...." I
didn't think he was writing only about ES4 participants. Among ES3
participants, is there strong agreement on disabling automatic
semicolon insertion in 3.1's strict mode?
>> This is a recipe for testing costs driving everyone away from all but
>> one mode, probably the one that's web-compatible.
> Anyone interested in software quality is horrified by the current
> strict or cautious subset.
I hope we can standardize a strict mode that increases software
quality. That's why I'm concerned, along with Lars, about strict mode
ruling out syntax (such as automatic semicolon insertion) that much
JS on the web relies on without noticeable quality problems. We want
a strict mode that will be both useful and usable at low incremental
('use strict' per block or script) cost.
BTW, we've had arguments in the past with Ajax library authors, who
write high quality code, about things like Firefox 1's "deprecated
with" warnings. Not everyone agrees with your idea of what is
horrible, and observed software quality problems do not correlate so
clearly to all those 3.1-unstrict bêtes noires.
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Es4-discuss