> On Dec 21, 2015, at 1:49 PM, Chris Lattner via swift-evolution 
> <[email protected]> wrote:
> 
> 
>> On Dec 21, 2015, at 12:05 PM, Jacob Bandes-Storch <[email protected] 
>> <mailto:[email protected]>> wrote:
>> 
>> On Mon, Dec 21, 2015 at 11:55 AM, Chris Lattner via swift-evolution 
>> <[email protected] <mailto:[email protected]>> wrote:
>> …there probably has to be some way to unsafely “force a call to a non-pure 
>> function to be allowed in a pure one”, both because of type system 
>> limitations as well as interoperability with C and other languages.  Even 
>> ignoring issues around errno, it would be sad for a pure function to not be 
>> able to call “sin(x)” just because it weren’t marked __attribute__((const)).
>> 
>> Minor tangent, but should the same apply to @noescape? 
> 
> Yes, it should.  I believe you can currently use an unsafe cast to remove 
> @noescape, and that the stdlib does it in a few places.  Dmitri, do you know 
> where?

The runtime does this using unsafeBitCast, but don't follow its example—I don't 
want to promise this will always be possible. There are representation 
optimizations we can do with @noescape closures that would be blocked if they 
always had to be bitcastable to refcounted escapable closures. I'd like to 
introduce a `Builtin.makeEscapable` operation specifically to go from @noescape 
to escapable, introducing a refcounting shim if necessary in the future.

-Joe
_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution

Reply via email to