<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body><div>Proposal PR submitted as&nbsp;<a href="https://github.com/apple/swift-evolution/pull/93">https://github.com/apple/swift-evolution/pull/93</a><br></div>
<div>&nbsp;</div>
<div>-Kevin Ballard<br></div>
<div>&nbsp;</div>
<div>On Sun, Dec 13, 2015, at 02:21 PM, Kevin Ballard wrote:<br></div>
<blockquote type="cite"><div>A function I find myself defining in a lot of my projects looks like the following:<br></div>
<div>&nbsp;<br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">/// Replace the value of `a` with `b` and return the old value.</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">public func replace&lt;T&gt;(inout a: T, with b: T) -&gt; T {</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">&nbsp;&nbsp;&nbsp; var value = b</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">&nbsp;&nbsp;&nbsp; swap(&amp;a, &amp;value)</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">&nbsp;&nbsp;&nbsp; return value</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">}</span><br></div>
<div>&nbsp;<br></div>
<div>This is a pretty simple function, and useful in a wide variety of circumstances, so I'd love to get it into the standard library. It doesn't actually enable any behavior that wasn't previously possible, but it does shrink some common code patterns, and I find the shorter code easier to read.<br></div>
<div>&nbsp;<br></div>
<div>An example of a place where I use it often is in replacing an optional property with a new value (or with nil) and cleaning up the previous value. Assuming a property like<br></div>
<div>&nbsp;<br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">var task: NSURLSessionTask?</span><br></div>
<div>&nbsp;<br></div>
<div>This replaces<br></div>
<div>&nbsp;<br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">if let task = self.task {</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">&nbsp; &nbsp; task.cancel()</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">}</span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">task = nil</span><br></div>
<div>&nbsp;<br></div>
<div>with<br></div>
<div>&nbsp;<br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">replace(&amp;task, with: nil)?.cancel()</span><br></div>
<div>&nbsp;<br></div>
<div>Or sometimes I use it like<br></div>
<div>&nbsp;<br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">if let value = replace(&amp;prop, with: newValue) {</span><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif"></span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">&nbsp; &nbsp; // multi-line cleanup</span><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif"></span><br></div>
<div><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif">}</span><span class="font" style="font-family:menlo, consolas, 'courier new', monospace, sans-serif"></span><br></div>
<div>&nbsp;<br></div>
<div>This is particularly nice if it's a COW value that I want to mutate, as it means I don't have to worry about getting unwanted copies due to the property still holding the old value while I muck with it.<br></div>
<div>&nbsp;<br></div>
<div>Question: For trivial backwards-compatible API changes like this, does a proposal PR need to be submitted to the swift-evolution repo, or is discussion on this ML sufficient before submitting a patch?<br></div>
<div>&nbsp;<br></div>
<div>-Kevin Ballard<br></div>
</blockquote><div>&nbsp;</div>
</body>
</html>