<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><br><div><br>On 28 Aug 2017, at 23:14, Jean-Daniel via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org">swift-evolution@swift.org</a>&gt; wrote:<br><br></div><blockquote type="cite"><div><meta http-equiv="Content-Type" content="text/html charset=utf-8"><br class=""><div><blockquote type="cite" class=""><div class="">Le 28 août 2017 à 06:14, Howard Lovatt via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; a écrit :</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">One of the biggest incumbents in this space on the server side is Java and its concurrency is based on futures and works very well (though there are a lot of libraries built on top of basic futures).&nbsp;</div></div></blockquote><div><br class=""></div><div>Most server side libraries don’t use Java Future as they force blocking at some point to get the future result. They instead have there own implementation that provide async completion handler (ListenableFuture, …), which result in the pattern we are trying to avoid with coroutine and async/await. &nbsp;This is not a very good example.</div></div></div></blockquote><div><br></div><div>JavaScript Promise + async/await and C# Task + async/await are good example though.</div><br><blockquote type="cite"><div><div><blockquote type="cite" class=""><div class=""><div class="gmail_extra">
<div class="gmail_quote">On 28 August 2017 at 12:35, Florent Vilmart <span dir="ltr" class="">&lt;<a href="mailto:florent@flovilmart.com" target="_blank" class="">florent@flovilmart.com</a>&gt;</span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">



<div class="">
<div name="messageBodySection" class="">Adam, you’re completely right, languages as c# and JS have been through the path before, (callback, Promises , async/await) I believe Chris’s goal it to avoid building a promise implementation and go straight to a coroutines model, which is more deeply integrated with the compiler. I don’t see a particular trade off, pursuing that route, and the main benefit is that coroutines can power any asynchronous metaphor (Signals, Streams, Futures, Promises etc...) which is not true of Futures so i would tend to think that for the long run, and to maximize usability, async/await/yield would probably be the way to go.</div><div class=""><div class="h5">
<div name="messageReplySection" class=""><br class="">
On Aug 27, 2017, 22:22 -0400, Adam Kemp &lt;<a href="mailto:adam.kemp@apple.com" target="_blank" class="">adam.kemp@apple.com</a>&gt;, wrote:<br class="">
<blockquote type="cite" class="">
<div class="">As has been explained, futures can be built on top of async/await (or the other way around). You can have the best of both worlds. We are not losing anything by having this feature. It would be a huge improvement to have this as an option.&nbsp;</div>
<div id="m_-6775134399349302246AppleMailSignature" class=""><br class=""></div>
<div id="m_-6775134399349302246AppleMailSignature" class="">However, using futures correctly requires more nested closures than you have shown in your examples to avoid blocking any threads. That's why you're not seeing the advantage to async/await. You're comparing examples that have very different behaviors.</div>
<div id="m_-6775134399349302246AppleMailSignature" class=""><br class=""></div>
<div id="m_-6775134399349302246AppleMailSignature" class="">That said, I have also expressed my opinion that it is better to build async/await on top of futures rather than the other way around. I believe it is more powerful and cleaner to make async/await work with any arbitrary future type (via a protocol). The alternative (building futures on top of async/await) requires more code when the two are mixed. I very much prefer how it's done in C#, where you can freely mix the two models without having to resort to ad-hoc wrappers, and you can use async/await with any futures implementation you might already be using.</div>
<div id="m_-6775134399349302246AppleMailSignature" class=""><br class=""></div>
<div id="m_-6775134399349302246AppleMailSignature" class="">I really think we should be having more discussion about the tradeoffs between those two approaches, and I'm concerned that some of the opinions about how C# does it are not based on a clear and accurate understanding of how it actually works in that language.&nbsp;</div>
<div id="m_-6775134399349302246AppleMailSignature" class=""><br class="">
--
<div class="">Adam Kemp</div>
</div>
<div class=""><br class="">
On Aug 27, 2017, at 6:02 PM, Howard Lovatt &lt;<a href="mailto:howard.lovatt@gmail.com" target="_blank" class="">howard.lovatt@gmail.com</a>&gt; wrote:<br class="">
<br class=""></div>
<blockquote type="cite" class="">
<div class="">
<div dir="ltr" class="">The async/await is very similar to the proposed Future (as I posed earlier) with regard to completion-handler code, they both re-write the imported completion-handler function using a closure, the relevant sentence from the Async Proposal is:
<div class=""><br class=""></div>
<blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px" class="">"Under the hood, the compiler rewrites this code using nested closures ..."<br class=""></blockquote>
<br class="">
<div class="">Unlike the proposed future code the async code is not naturally parallel, in the running example the following lines from the async code are run in series, i.e. await blocks:</div>
<div class=""><br class=""></div>
<div class="">
<pre style="box-sizing:border-box;font-family:SFMono-Regular,Consolas,&quot;Liberation Mono&quot;,Menlo,Courier,monospace;font-size:13.6px;margin-top:0px;margin-bottom:0px;font-stretch:normal;line-height:1.45;word-wrap:normal;padding:16px;overflow:auto;background-color:rgb(246,248,250);border-radius:3px;word-break:normal;color:rgb(36,41,46)" class="">  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">let</span> dataResource  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">=</span> await <span class="m_-6775134399349302246gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,92,197)">loadWebResource</span>(<span class="m_-6775134399349302246gmail-pl-s" style="box-sizing:border-box;color:rgb(3,47,98)"><span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span>dataprofile.<wbr class="">txt<span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span></span>)
  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">let</span> imageResource <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">=</span> await <span class="m_-6775134399349302246gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,92,197)">loadWebResource</span>(<span class="m_-6775134399349302246gmail-pl-s" style="box-sizing:border-box;color:rgb(3,47,98)"><span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span>imagedata.dat<span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box"><wbr class="">"</span></span>)
</pre></div>
<div class="">The equivalent lines using the proposed Future:</div>
<div class="">
<pre style="box-sizing:border-box;font-family:SFMono-Regular,Consolas,&quot;Liberation Mono&quot;,Menlo,Courier,monospace;font-size:13.6px;margin-top:0px;margin-bottom:0px;font-stretch:normal;line-height:1.45;word-wrap:normal;padding:16px;overflow:auto;background-color:rgb(246,248,250);border-radius:3px;word-break:normal;color:rgb(36,41,46)" class="">  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">let</span> dataResource  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">=</span> <span class="m_-6775134399349302246gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,92,197)">loadWebResource</span>(<span class="m_-6775134399349302246gmail-pl-s" style="box-sizing:border-box;color:rgb(3,47,98)"><span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span>dataprofile.<wbr class="">txt<span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span></span>)
  <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">let</span> imageResource <span class="m_-6775134399349302246gmail-pl-k" style="box-sizing:border-box;color:rgb(215,58,73)">=</span> <span class="m_-6775134399349302246gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,92,197)">loadWebResource</span>(<span class="m_-6775134399349302246gmail-pl-s" style="box-sizing:border-box;color:rgb(3,47,98)"><span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box">"</span>imagedata.dat<span class="m_-6775134399349302246gmail-pl-pds" style="box-sizing:border-box"><wbr class="">"</span></span>)
</pre></div>
<div class="">Run in parallel and therefore are potentially faster assuming that resources, like cores and IO, are available.</div>
<div class=""><br class=""></div>
<div class="">Therefore you would be better using a Future than an async, so why provide an async unless you can make a convincing argument that it allows you to write a better future?</div>
</div>
<div class="gmail_extra"><br clear="all" class="">
<div class="">
<div class="m_-6775134399349302246gmail_signature" data-smartmail="gmail_signature">&nbsp; -- Howard.<br class=""></div>
</div>
<br class="">
<div class="gmail_quote">On 28 August 2017 at 09:59, Adam Kemp <span dir="ltr" class="">&lt;<a href="mailto:adam.kemp@apple.com" target="_blank" class="">adam.kemp@apple.com</a>&gt;</span> wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="auto" class="">This example still has nested closures (to create a Future), and still relies on a synchronous get method that will block a thread. Async/await does not require blocking any threads.
<div class=""><br class=""></div>
<div class="">I’m definitely a fan of futures, but this example isn’t even a good example of using futures. If you’re using a synchronous get method then you’re not using futures properly. They’re supposed to make it easy to avoid writing blocking code. This example just does the blocking call on some other thread.</div>
<div class=""><br class=""></div>
<div class="">Doing it properly would show the benefits of async/await because it would require more nesting and more complex error handling. By simplifying the code you’ve made a comparison between proper asynchronous code (with async/await) and improper asynchronous code (your example).</div>
<div class=""><br class=""></div>
<div class="">That tendency to want to just block a thread to make it easier is exactly why async/await is so valuable. You get simple code while still doing it correctly.&nbsp;</div>
<div class=""><br class="">
<div id="m_-6775134399349302246m_-2707032511043914185AppleMailSignature" class="">--
<div class="">Adam Kemp</div>
</div>
<div class="">
<div class="m_-6775134399349302246h5">
<div class=""><br class="">
On Aug 27, 2017, at 4:00 PM, Howard Lovatt via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>&gt; wrote:<br class="">
<br class=""></div>
<blockquote type="cite" class="">
<div class="">
<div class="">
<div dir="auto" class="">The running example used in the white paper coded using a Future is:</div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class=""><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">func processImageData1() -&gt; Future&lt;Image&gt; {</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; return AsynchronousFuture { _ -&gt; Image in</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; &nbsp; &nbsp; let dataResource &nbsp;= loadWebResource("dataprofile.</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">t<wbr class="">xt") // dataResource and imageResource run in parallel.</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; &nbsp; &nbsp; let imageResource = loadWebResource("imagedata.</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">dat<wbr class="">")</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; &nbsp; &nbsp; let imageTmp &nbsp; &nbsp; &nbsp;= decodeImage(dataResource.get ?? Resource(path: "Default data resource or prompt user"), imageResource.get ?? Resource(path: "Default image resource or prompt user"))</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; &nbsp; &nbsp; let imageResult &nbsp; = &nbsp;dewarpAndCleanupImage(</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">imageTm<wbr class="">p.get ?? Image(dataPath: "Default image or prompt user", imagePath: "Default image or prompt user"))</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; &nbsp; &nbsp; return imageResult.get ?? Image(dataPath: "Default image or prompt user", imagePath: "Default image or prompt user")</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; }</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">}</span><br class=""></div>
<div dir="auto" class=""><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class=""><br class=""></span></div>
<div dir="auto" class="">This also avoids the pyramid of doom; the pyramid is avoided by converting continuation-handlers into either a sync or future, i.e. it is the importer that eliminates the nesting by translating the code automatically.&nbsp;<br class=""></div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class="">This example using Future also demonstrates three advantages of Future: they are naturally parallel (dataResource and imageResource lines run in parallel), they timeout automatically (get returns nil if the Future has taken too long), and if there is a failure (for any reason including timeout) it provides a method of either detecting the failure or providing a default (get returns nil on failure).&nbsp;</div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class="">There are a three of other advantages a Future has that this example doesn’t show: control over which thread the Future runs on, Futures can be cancelled, and debugging information is available.</div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class="">You could imagine `async` as a syntax sugar for Future, e.g. the above Future example could be:</div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class="">
<div dir="auto" class=""><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">func processImageData1() async -&gt; Image {</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; let dataResource &nbsp;= loadWebResource("dataprofile.</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">t<wbr class="">xt") // dataResource and imageResource run in parallel.</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; let imageResource = loadWebResource("imagedata.</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">dat<wbr class="">")</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; let imageTmp &nbsp; &nbsp; &nbsp;= decodeImage(dataResource.get ?? Resource(path: "Default data resource or prompt user"), imageResource.get ?? Resource(path: "Default image resource or prompt user"))</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; let imageResult &nbsp; = &nbsp;dewarpAndCleanupImage(</span><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">imageTm<wbr class="">p.get ?? Image(dataPath: "Default image or prompt user", imagePath: "Default image or prompt user"))</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">&nbsp; &nbsp; return imageResult.get ?? Image(dataPath: "Default image or prompt user", imagePath: "Default image or prompt user")</span><br style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px" class="">
<span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">}</span><br class=""></div>
<div dir="auto" class=""><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class=""><br class=""></span></div>
<div dir="auto" class="">Since an async is sugar for Future the async runs as soon as it is created (as soon as the underlying Future is created) and get returns an optional (also cancel and status would be still be present). Then if you want control over threads and timeout they could be arguments to async:</div>
<div dir="auto" class=""><br class=""></div>
<div dir="auto" class=""><span style="color:rgb(117,117,117);font-family:monospace,monospace;word-spacing:1px;background-color:rgb(255,255,255)" class="">func processImageData1() async(queue: DispatchQueue.main, timeout: .seconds(5)) -&gt; Image { ... }</span><br class=""></div>
</div>
<br class="">
<div class="gmail_quote">
<div class="">On Sat, 26 Aug 2017 at 11:00 pm, Florent Vilmart &lt;<a href="mailto:florent@flovilmart.com" target="_blank" class="">florent@flovilmart.com</a>&gt; wrote:<br class=""></div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="">
<div name="messageBodySection" class="">Howard, with async / await, the code is flat and you don’t have to unowned/weak self to prevent hideous cycles in the callbacks.<br class="">
Futures can’t do that</div>
</div>
<div class="">
<div name="messageReplySection" class=""><br class="">
On Aug 26, 2017, 04:37 -0400, Goffredo Marocchi via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>&gt;, wrote:<br class="">
<blockquote type="cite" class="">With both he now built in promises in Node8 as well as libraries like Bluebird there was ample time to evaluate them and convert/auto convert at times libraries that loved callback pyramids of doom when the flow grows complex into promise based chains. Converting to Promises seems magical for the simple case, but can quickly descend in hard to follow flows and hard to debug errors when you move to non trivial multi path scenarios. JS is now solving it with their implementation of async/await, but the point is that without the full picture any single solution would break horribly in real life scenarios.<br class="">
<br class="">
<div id="m_-6775134399349302246m_-2707032511043914185m_-3623957891747021796AppleMailSignature" class="">Sent from my iPhone</div>
<div class=""><br class="">
On 26 Aug 2017, at 06:27, Howard Lovatt via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>&gt; wrote:<br class="">
<br class=""></div>
<blockquote type="cite" class="">
<div class="">
<div class="">My argument goes like this:
<div class=""><br class="">
<div class="">&nbsp; 1. You don't need async/await to write a powerful future type; you can use the underlying threads just as well, i.e. future with async/await is no better than future without.&nbsp;</div>
<div class=""><br class=""></div>
<div class="">&nbsp; 2. Since future is more powerful, thread control, cancel, and timeout, people should be encouraged to use this; instead because async/await are language features they will be presumed, incorrectly, to be the best way, consequently people will get into trouble with deadlocks because they don't have control.</div>
</div>
<div class=""><br class=""></div>
<div class="">&nbsp; 3. async/await will require some engineering work and will at best make a mild syntax improvement and at worst lead to deadlocks, therefore they just don't carry their weight in terms of useful additions to Swift.</div>
<div class=""><br class=""></div>
<div class="">Therefore, save some engineering effort and just provide a future library.</div>
<div class=""><br class=""></div>
<div class="">To turn the question round another way, in two forms:</div>
<div class=""><br class=""></div>
<div class="">&nbsp; 1. What can async/wait do that a future can't?</div>
<div class=""><br class=""></div>
<div class="">&nbsp; 2. How will future be improved if async/await is added?</div>
<div class=""><br class=""></div>
</div>
<div class="gmail_extra"><br clear="all" class="">
<div class="">
<div class="m_-6775134399349302246m_-2707032511043914185m_-3623957891747021796gmail_signature" data-smartmail="gmail_signature">&nbsp; -- Howard.<br class=""></div>
</div>
<br class="">
<div class="gmail_quote">On 26 August 2017 at 02:23, Joe Groff <span class="">&lt;<a href="mailto:jgroff@apple.com" target="_blank" class="">jgroff@apple.com</a>&gt;</span> wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word" class="">
<div class=""><br class="">
<div class="">
<blockquote type="cite" class="">
<div class="">On Aug 25, 2017, at 12:34 AM, Howard Lovatt &lt;<a href="mailto:howard.lovatt@gmail.com" target="_blank" class="">howard.lovatt@gmail.com</a>&gt; wrote:</div>
<br class="m_-6775134399349302246m_-2707032511043914185m_-3623957891747021796m_1547456930512826529Apple-interchange-newline">
<div class=""><span style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant-caps:normal;font-weight:normal;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;float:none;display:inline!important" class=""><span class="m_-6775134399349302246m_-2707032511043914185m_-3623957891747021796m_1547456930512826529Apple-converted-space">&nbsp;</span>In particular a future that is cancellable is more powerful that the proposed async/await.</span></div>
</blockquote>
</div>
<br class=""></div>
<div class="">It's not more powerful; the features are to some degree disjoint. You can build a Future abstraction and then use async/await to sugar code that threads computation through futures. Getting back to Jakob's example, someone (maybe the Clang importer, maybe Apple's framework developers in an overlay) will still need to build infrastructure on top of IBActions and other currently ad-hoc signalling mechanisms to integrate them into a more expressive coordination framework.</div>
<div class="m_-6775134399349302246m_-2707032511043914185m_-3623957891747021796HOEnZb"><font color="#888888" class=""></font>
<div class=""><font color="#888888" class=""><br class=""></font></div>
<div class=""><font color="#888888" class="">-Joe</font></div>
</div>
</div>
</blockquote>
</div>
<br class=""></div>
</div>
</blockquote>
<blockquote type="cite" class="">
<div class=""><span class="">______________________________<wbr class="">_________________</span><br class="">
<span class="">swift-evolution mailing list</span><br class="">
<span class=""><a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a></span><br class="">
<span class=""><a href="https://lists.swift.org/mailman/listinfo/swift-evolution" target="_blank" class="">https://lists.swift.org/mailma<wbr class="">n/listinfo/swift-evolution</a></span><br class=""></div>
</blockquote>
</blockquote>
</div>
</div>
</blockquote>
</div>
</div>
<div dir="ltr" class="">--<br class=""></div>
<div class="m_-6775134399349302246m_-2707032511043914185gmail_signature" data-smartmail="gmail_signature">-- Howard.</div>
</div>
</blockquote>
<blockquote type="cite" class="">
<div class=""><span class="">______________________________<wbr class="">_________________</span><br class="">
<span class="">swift-evolution mailing list</span><br class="">
<span class=""><a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a></span><br class="">
<span class=""><a href="https://lists.swift.org/mailman/listinfo/swift-evolution" target="_blank" class="">https://lists.swift.org/mailma<wbr class="">n/listinfo/swift-evolution</a></span><br class=""></div>
</blockquote>
</div>
</div>
</div>
</div>
</blockquote>
</div>
<br class=""></div>
</div>
</blockquote>
</blockquote>
</div>
</div></div></div>

</blockquote></div><br class=""></div>
_______________________________________________<br class="">swift-evolution mailing list<br class=""><a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a><br class=""><a href="https://lists.swift.org/mailman/listinfo/swift-evolution">https://lists.swift.org/mailman/listinfo/swift-evolution</a><br class=""></div></blockquote></div><br class=""></div></blockquote><blockquote type="cite"><div><span>_______________________________________________</span><br><span>swift-evolution mailing list</span><br><span><a href="mailto:swift-evolution@swift.org">swift-evolution@swift.org</a></span><br><span><a href="https://lists.swift.org/mailman/listinfo/swift-evolution">https://lists.swift.org/mailman/listinfo/swift-evolution</a></span><br></div></blockquote></body></html>