<p dir="ltr">There's also this strawman of mine which deals with most things async, but it has several of its own issues that I haven't quite addressed (complexity still being one after a week straight):</p>
<p dir="ltr"><a href="https://github.com/isiahmeadows/non-linear-proposal">https://github.com/isiahmeadows/non-linear-proposal</a></p>
<p dir="ltr">I will caution that async iteration and observation can't really be merged meaningfully as you would hope. They both represent multiple values over time, but one is eager, the other lazy.</p>
<br><div class="gmail_quote"><div dir="ltr">On Sat, Jul 29, 2017, 06:54 Naveen Chawla <<a href="mailto:naveen.chwl@gmail.com">naveen.chwl@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Interesting!!!<div><br></div><div>Excuse my ignorance, but with this construct, how would you trivially invoke a "publish" ahead of any given "consumption"?</div><div><br></div><div>As far as I can see,</div><div><br></div><div>```</div><div>for await (const item of requestItems){</div><div><br></div><div>}</div><div>```</div><div>on its own is purely a "front-pressure" construct. That is, each request is made upon the completion and satisfactory consumption of the last one.</div><div><br></div><div>Can you suggest a way to trivially invoke some "back pressure" using this construct? By this I mean - invoke extra requests before they come to be consumed (like you can do with reactive streaming libraries). An example use would be if you wanted to do some "eager loading" of data while the user is likely to be viewing but not currently interacting with existing content, for example.</div><div><br></div><div>You seem very familiar with this construct, so I wouldn't be surprised if you've already thought about this! (If you're too busy I'm sure there are others here familiar with it too!)</div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, 11 Jul 2017 at 21:09 Domenic Denicola <<a href="mailto:d@domenic.me" target="_blank">d@domenic.me</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">





<div lang="EN-US" link="blue" vlink="purple">
<div class="m_4290855357875344310m_8933829226000339919WordSection1">
<p class="MsoNormal"><a href="https://github.com/tc39/proposal-async-iteration" target="_blank">https://github.com/tc39/proposal-async-iteration</a><u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><b>From:</b> es-discuss [mailto:<a href="mailto:es-discuss-bounces@mozilla.org" target="_blank">es-discuss-bounces@mozilla.org</a>]
<b>On Behalf Of </b>Naveen Chawla<br>
<b>Sent:</b> Tuesday, July 11, 2017 09:24<br>
<b>To:</b> <a href="mailto:es-discuss@mozilla.org" target="_blank">es-discuss@mozilla.org</a><br>
<b>Subject:</b> Stream + async await<u></u><u></u></p></div></div><div lang="EN-US" link="blue" vlink="purple"><div class="m_4290855357875344310m_8933829226000339919WordSection1">
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p class="MsoNormal">It'd be great to have async stream constructs such as: <a href="http://reactivex.io/rxjs/" target="_blank">http://reactivex.io/rxjs/</a> , supported natively, such that they can be used directly with the async / await keywords for async stream programming
 in a linear fashion (analogous to what can already be done with linearly awaiting Promises, but for async streams instead).<u></u><u></u></p>
</div>
</div></div></blockquote></div>
_______________________________________________<br>
es-discuss mailing list<br>
<a href="mailto:es-discuss@mozilla.org" target="_blank">es-discuss@mozilla.org</a><br>
<a href="https://mail.mozilla.org/listinfo/es-discuss" rel="noreferrer" target="_blank">https://mail.mozilla.org/listinfo/es-discuss</a><br>
</blockquote></div>