IMO this is a boundary problem.
How far do you want to go in letting the compiler deduce the actual type?
It is possible to make very elaborate constructs that would basically default 
to a complex tuple/array/dictionary construct with only Any?’s in them. (well, 
the dict would require a Hashable too)

Besides, the recent discussion on compile times illustrates another angle to 
this problem: if type inference is used extensively, compile times go to 
infinite…

So while I do not know if this is a bug or not, I would recommend not to use it 
anyhow.

Regards,
Rien

Site: http://balancingrock.nl
Blog: http://swiftrien.blogspot.com
Github: http://github.com/Balancingrock
Project: http://swiftfire.nl





> On 24 Mar 2017, at 11:08, Toni Suter via swift-users <swift-users@swift.org> 
> wrote:
> 
> Hi,
> 
> If I declare a variable and initialize it with an array literal whose 
> elements are integer literals and nil literals,
> the compiler will infer the type Array<Optional<Int>> for that variable:
> 
> let arr = [1, nil, 3]
> print(type(of: arr))  // Array<Optional<Int>>
> 
> However, that only works with nominal types such as Int and String. If I do 
> the same thing with an array of tuples,
> I get a compile error:
> 
> let arr = [(1, false), nil, (3, true)]                // error: type of 
> expression is ambiguous without more context
> print(type(of: arr))
> 
> Why can't the compiler infer the type Array<Optional<(Int, Bool)>> in this 
> example? Is there a reason for this or is it a bug?
> 
> Thanks and best regards,
> Toni
> 
> _______________________________________________
> swift-users mailing list
> swift-users@swift.org
> https://lists.swift.org/mailman/listinfo/swift-users

_______________________________________________
swift-users mailing list
swift-users@swift.org
https://lists.swift.org/mailman/listinfo/swift-users

Reply via email to