Hi,

I had the same problem with delegate methods (they all had the same prefix). I 
used lambda as a workaround, but I agree it is less elegant :

let b: = { Foo(customNumber: $0) }
let c: = { Foo(numberToInc: $0) }


Pierre

> Le 10 déc. 2015 à 23:41, Austin Zheng via swift-users <[email protected]> 
> a écrit :
> 
> Hello Swift users,
> 
> I have a question about capturing references to initializers. You can do the 
> following right now:
> 
> struct Foo {
>     let number : Int
>     // This type has a single initializer
>     init() {
>         number = 10
>     }
> }
> 
> let a  = Foo.init  // a's type: () -> Foo
> 
> So far so good. Now, let's add in a second initializer:
> 
> extension Foo {
>     init(customNumber: Int) {
>         number = customNumber
>     }
> }
> 
> Now, if you want to capture a reference to one of the initializers, you can 
> annotate the variable with the explicit function type:
> 
> let a : () -> Foo = Foo.init
> let b : Int -> Foo = Foo.init
> 
> My question involves the case where you have multiple initializers that take 
> the same arguments and types. How would you capture initializers then?
> 
> extension Foo {
>     init(numberToInc: Int) {
>         number = numberToInc + 1
>     }
> }
> 
> How do I capture a reference to the numberToInc: initializer, versus the 
> customNumber: initializer?
> 
> Best regards,
> Austin
>  _______________________________________________
> swift-users mailing list
> [email protected]
> https://lists.swift.org/mailman/listinfo/swift-users

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

Reply via email to