Correct me if I’m wrong but a variadic argument is guaranteed to have one or
more elements in the array. Isn’t that the case? As an example, consider the
following initializer:
public init(state: State, actions: Action...) {
// ...
}
Here, I can count on actions to be a non-empty array. It’s self-documenting and
type-safe. How would this work if arrays are (implicitly or explicitly)
convertible to variadic arguments?
R+
> On 26 Feb 2017, at 17:26, Derrick Ho via swift-evolution
> <[email protected]> wrote:
>
> In swift, a variadic argument can become an array without too much effort.
>
> func foo(_ va: String...) {
> let a: [String] = va
> }
>
> However, it seems odd to me that an array can not be converted into a
> variadic argument
>
> foo(["a", "b", "c"]) // <-error
> foo("a", "b", "c") // no error
>
> Other people have wondered about this too.
> <http://stackoverflow.com/questions/24024376/passing-an-array-to-a-function-with-variable-number-of-args-in-swift>
>
> According to this thread <https://devforums.apple.com/message/970958#970958>
> Doug Gregor says it is due to some type ambiguity. with Generics.
>
> If type ambiguity is the issue, Do we have the option to cast it to the
> correct type?
>
> foo(["a", "b", "c"] as String...) // <- error. doesn't consider String... to
> be a type.
>
> What does the community think? Should we be granted some mechanism to turn an
> array into a variadic argument?
> _______________________________________________
> swift-evolution mailing list
> [email protected]
> https://lists.swift.org/mailman/listinfo/swift-evolution
_______________________________________________
swift-evolution mailing list
[email protected]
https://lists.swift.org/mailman/listinfo/swift-evolution