[swift-users] overloading methods where only difference is optional vs. non-optional type

C. Keith Ray keithray at mac.com
Tue Oct 10 12:27:31 CDT 2017


nope. it's the same as this example:

func funny() -> Int {
 return 1
}

func funny() -> String {
 return "2"
}

print(funny()) // the compiler doesn't know which one you want.

// the above doesn't compile.
// error: forloop.playground:8:1: error: ambiguous use of 'funny()'


You have to have some difference visible in the caller:


func funny(useInt: Bool) -> Int {
 return 1
}

func funny(useString: Bool) -> String {
 return "2"
}

print(funny(useInt: true), funny(useString: true))
// prints "1 2\n"


--
C. Keith Ray
Senior Software Engineer / Trainer / Agile Coach
* http://www.thirdfoundationsw.com/keith_ray_resume_2014_long.pdf
* https://leanpub.com/wepntk <https://leanpub.com/wepntk> <- buy my book?


> On Oct 10, 2017, at 9:06 AM, Phil Kirby via swift-users <swift-users at swift.org> wrote:
> 
>  <>2 down vote <> favorite <https://stackoverflow.com/questions/46620311/overloading-methods-where-only-difference-is-optional-vs-non-optional-type#> 
> Original StackOverflow post:
> 
> https://stackoverflow.com/questions/46620311/overloading-methods-where-only-difference-is-optional-vs-non-optional-type <https://stackoverflow.com/questions/46620311/overloading-methods-where-only-difference-is-optional-vs-non-optional-type>
> I was under the impression that swift can have overloaded methods that differ only in the type of object that the methods return. I would think that I could have two funcs with the same signature yet they differ in return type.
> 
> import Foundation
> 
> // ambiguous use of 'IsTextEmpty(text:)'
> func IsTextEmpty(text : String?) -> Bool? {
>   return text?.isEmpty
> }
> 
> func IsTextEmpty(text : String?) -> Bool {
>    guard let text = text else {
>      return true
>    }
> 
>    return text.isEmpty
> }
> 
> let text: String? = nil
> 
> if let empty = IsTextEmpty(text:"text") {
>    print("Not Empty")
> }
> 
> if IsTextEmpty(text: text) {
>    print("Empty")
> }
> Here, both functions have the same input parameters but one func returns an optional Bool? and the other returns a Bool. In this case I get an error:
> 
> ambiguous use of 'IsTextEmpty(text:)'
> If I change the name of one of the input parameters I no longer get the ambiguous error:
> 
> // Works
> func IsTextEmpty(foo : String?) -> Bool? {
>   return foo?.isEmpty
> }
> 
> func IsTextEmpty(text : String?) -> Bool {
>    guard let text = text else {
>      return true
>    }
> 
>    return text.isEmpty
> }
> 
> let text: String? = nil
> 
> if let empty = IsTextEmpty(foo:"text") {
>    print("Not Empty")
> }
> 
> if IsTextEmpty(text: text) {
>    print("Empty")
> }
> Shouldn't the compiler detect that they are two distinct methods even though their return types are different, since an optional Bool? is a different type from a non-optional Bool?
> 
> 
> _______________________________________________
> swift-users mailing list
> swift-users at swift.org
> https://lists.swift.org/mailman/listinfo/swift-users

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-users/attachments/20171010/86966c06/attachment.html>


More information about the swift-users mailing list