On Thu, Jun 23, 2011 at 6:44 PM, Brendan Eich <span dir="ltr"><<a href="mailto:brendan@mozilla.com" target="_blank">brendan@mozilla.com</a>></span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<div>On Jun 23, 2011, at 5:16 PM, Mark S. Miller wrote:<br>
<br>
> Arrow functions:<br>
><br>
>     keys: function() {<br>
>       return this.getOwnPropertyNames().filter(<br>
>         (name) -> this.getOwnPropertyDescriptor(name).enumerable );<br>
>     }<br>
<br>
</div>This is not giving arrow functions their due, though. Just use => and all is well.<br></blockquote><div><br></div><div>[...]</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">

<div>
> As fallible programmers, we can only afford a more compact function notation for defining functions with lexical "this" -- like block lambdas.<br>
<br>
</div>Or =>?<br>
<br>
I'm leaning toward block lambdas myself, but I feel the need to play umpire here a bit -- arrows need fair play including =>, not just ->.</blockquote><div><br></div><div>Hi Brendan, I appreciate the umpire role. You do it well.</div>

<div><br></div><div>I had indeed forgotten that => was part of the arrow function proposal. This does make it much less likely that Tom would have made the mistake if he'd been programming in JS-with-arrow-functions. But my real point is, if he had made the mistake using "->", would we have been more or less likely to catch it than in the code he wrote using "function"?</div>

<div><br></div><div>When we talk about syntax, we often focus on the difficultly of writing code, somewhat on the hazards of writing code correctly, and on the difficulty of reading and comprehending correct code. What this thread clarified for me is <span style="font-family:arial, sans-serif;font-size:13px;background-color:rgb(255, 255, 255)">how little we talk about syntax's influence on our ability to spot problems when reading code, and that we need to focus on that more. </span> </div>

</div><div><br></div>Presently in JS, when seeing a "this", to understand what it means, the eye needs to scan backwards for the closest enclosing occurrence of "function" as a keyword. As this example shows, even this is accident prone. If we introduce multiple special forms that can introduce a this-rebinding boundary, where the new ones are easily missed, we make this burden worse. Is "->" easily missed? (I would guess so.) And if it is, what are we getting in exchange, and is it worth it?<div>

<br>-- <br>    Cheers,<br>    --MarkM<br>
</div>