<div dir="ltr">Thanks, I wasn't aware of `do` expressions.<div><br></div><div>> <span style="font-size:12.8px">Why introduce the function and cognitive overhead?</span></div><span class="gmail-im" style="font-size:12.8px"></span><div><br></div><div>Not that it really matters (I was just giving an example) but your alternative isn't achieving the same thing, which is to set a default to width and height if and only if *neither* height or width is set. (e.g. thumb({ width: 100 }) should set `w = 100` and `h = undefined` not `w = 100` and `h = 400` but thumb({}) should set `w=400` and `h=400`.</div><div> </div><div>Anyways, I'll try to find out what those do expressions are about.</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Sep 29, 2016 at 3:59 PM, Rick Waldron <span dir="ltr"><<a href="mailto:waldron.rick@gmail.com" target="_blank">waldron.rick@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><br><div class="gmail_quote"><span class=""><div dir="ltr">On Thu, Sep 29, 2016 at 3:14 PM Michał Wadas <<a href="mailto:michalwadas@gmail.com" target="_blank">michalwadas@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr">Similar proposal is already here, do expressions.</p></blockquote><div><br></div></span><div>Additionally... </div><span class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr"> </p>
<div class="gmail_extra"><br><div class="gmail_quote">On 30 Sep 2016 12:06 a.m., "Olivier Lalonde" <<a href="mailto:olalonde@gmail.com" target="_blank">olalonde@gmail.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">I occasionally write IIFE to avoid introducing `let` variables, e.g.:<div><br></div><div>```</div><div><div>const thumb = ({ width, height }) => {</div><div>  const { w, h } = (() => {</div><div>    // if either width or height is set, don't set any default</div><div>    if (Number.isInteger(width) || Number.isInteger(height)) {</div><div>      return { w: width, h: height }</div><div>    }</div><div>    return { w: 400, h: 400 }</div><div>  })()</div><div>  // ...</div><div>}</div><div>```</div></div></div></blockquote></div></div></blockquote><div><br></div></span><div><div>Why introduce the function and cognitive overhead?</div><span class=""><div><br></div><div>const thumb = ({ width, height }) => {</div></span><div>  const w = Number.isInteger(width) ? width : 400;</div><div>  const h = Number.isInteger(height) ? height : 400;<br></div><div>  // ...</div><div>}</div><div><br></div><div><br></div><div>Either way, `do` expressions are what you're looking for.</div><span class="HOEnZb"><font color="#888888"><div><br></div><div><br></div><div>Rick</div></font></span></div></div></div>
</blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div>- Oli</div><div><br><font color="#999999">Olivier Lalonde</font></div><div><a href="http://www.syskall.com/" target="_blank">http://www.syskall.com</a> <-- connect with me!</div></div></div></div></div>
</div>