||= is much needed?
Brendan Eich
brendan at mozilla.org
Tue Jun 12 11:02:44 PDT 2012
Wes Garland wrote:
> > This breaks from JS's C-inspired assignment operators, but perhaps
> we can live with it.
>
> FWIW -- I was confused when I first read ||=, I thought it was
> supposed to be some kind of Boolean-coercing variant on |=. Now I see
> that it is more like ?= from GNU make.
We could use ?= instead. Good point. This avoids the dual semantics for
A op= B split on whether op is || (an existing operator, unlike lone ?).
> What do you think of GCC's ?: operator? It is basically a special form
> of the ternary operator, and while not the same as your propsal, it
> addresses many of the same use cases.
That's ok as an alternative to ?? but would you want ?:= as the
assignment form? I'd rather lose the colon.
Given ?=, people may wish for A ? B instead of A ?? B, but then we have
nasty issues with respect to ternary:
A ? B ? C : D
Is this (A ? B) ? C : D or A ? (B ? C) : D. We can disambiguate in the
formal grammar but readers may rebel.
It's possible ?? or however we spell it isn't worth adding, while ?= is.
The conditional assignment to default or normalize is the prime use-case.
Even then, we have lingering debates over falsy vs. null-or-undefined
vs. undefined only. CoffeeScript does null-or-undefined, IIRC.
/be
>
> (I've been happy with it for a long time).
>
> Wes
>
> --
> Wesley W. Garland
> Director, Product Development
> PageMail, Inc.
> +1 613 542 2787 x 102
> _______________________________________________
> es-discuss mailing list
> es-discuss at mozilla.org
> https://mail.mozilla.org/listinfo/es-discuss
More information about the es-discuss
mailing list