[swift-evolution] [Proposal] Make optional protocol methods first class citizens

Thorsten Seitz tseitz42 at icloud.com
Mon Apr 4 00:21:12 CDT 2016

As the problem seems to be to eliminate having to write the extension with all its duplication, I'd prefer a more general solution instead of introducing the notion of an "optional" function: just make it possible to write default implementations inline in a protocol definition. 

Documenting the optionality can be done in the doc comment, maybe with a new documentation keyword "default". Having "optional" in the code has no additional value over a comment because the method is not optional in the Obj-C sense and the proposal requires a default value. Therefore the presence of "optional" has essentially no effect at all and is better moved into a comment.


> Am 04.04.2016 um 00:13 schrieb Chris Lattner via swift-evolution <swift-evolution at swift.org>:
>>> On Apr 3, 2016, at 10:40 AM, Andrey Tarantsov <andrey at tarantsov.com> wrote:
>>> Protocol requirements with default (no-op) implementations already satisfy that design goal, no?
>> Chris, as we've discussed in a thread that I think got forked from this one:
>> Yes, they do technically, but it would be nice to both:
>> 1) make it an obvious documented part of the signature, possibly including the default return value
>> 2) possibly make it less verbose by getting rid of the explicitly spelled out protocol extension
> Right, but “more is worse” when it comes to language design.  Having a "more general" facility that greatly overlaps with a “more narrow” facility always makes us question whether it is worth the complexity to have both.
> -Chris
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org
> https://lists.swift.org/mailman/listinfo/swift-evolution
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-evolution/attachments/20160404/b58c5037/attachment.html>

More information about the swift-evolution mailing list