Files
swift-mirror/test/decl/func/keyword-argument-defaults.swift
Chris Lattner cf2e7f6f45 Fix SR-718: Type mismatch reported as extraneous parameter
The issue here is that the constraint solver was deciding on
FixKind::RelabelCallTuple as the fix for the problem and emitting the
diagnostic, even though there were two different fixes possible.

CSDiags has the infrastructure to support doing doing the right thing
here, but is only being used for ApplyExprs, not SubscriptExprs.

The solution is to fix both problems: remove FixKind::RelabelCallTuple,
to let CSDiags handle the problem, and enhance CSDiags to treat
SubscriptExpr more commonly with ApplyExpr.  This improves several cases
where the solver was picking one solution randomly and suggesting that
as a fix, instead of listing that there are multiple different solutions.
2016-02-12 17:19:54 -08:00

122 lines
3.9 KiB
Swift

// RUN: %target-parse-verify-swift
// The first function argument does not have a label; the others do.
func f1(a: Int, b: Int) { }
func f1(a: Int, d: Int) { } // okay: names differ
func f2(a: Int, b: Int) { } // expected-note{{'f2(_:b:)' previously declared here}}
func f2(z: Int, b: Int) { } // expected-error{{invalid redeclaration of 'f2(_:b:)'}}
class X {
// Initializer arguments are API by default.
init(x: Int) { }
init(y: Int) { } // okay
// Method arguments after the first are API by default
func f1(a: Int, b: Int) { }
func f1(a: Int, c: Int) { } // okay
func f2(a: Int, b: Int) { } // expected-note{{'f2(_:b:)' previously declared here}}
func f2(A: Int, b: Int) { } // expected-error{{invalid redeclaration of 'f2(_:b:)'}}
}
protocol P {
func g1(value: Int)
func g2(value: Int, other: Int)
func g3(value: Int, other: Int, third: Int) // expected-note{{requirement 'g3(_:other:third:)' declared here}}
static func g4(value: Int)
}
class PX : P {
func g1(x: Int) { } // okay
func g2(x: Int, other: Int) { } // okay
func g3(x: Int, y: Int, third: Int) { } // expected-error{{method 'g3(_:y:third:)' has different argument names from those required by protocol 'P' ('g3(_:other:third:)')}} {{19-19=other }}
class func g4(x: Int) { }
}
// Default arguments have no effect on argument labels.
func f3(a: Int, b: Int = 5, c: Int = 6) { }
// expected-note@-1{{'f3(_:b:c:)' previously declared here}}
func f3(a: Int, b: Int, c: Int) { }
// expected-error@-1{{invalid redeclaration of 'f3(_:b:c:)'}}
class DefArg {
func f(a: Int = 17) { } // okay: no label implied
func f(a a: Int) { }
}
struct Subscripts1 {
subscript (i i: Int) -> Int {
get { return i }
}
subscript (j j: Int) -> Int {
get { return j }
}
}
struct Subscripts2 {
subscript (i: Int) -> Int { // expected-note{{'subscript' previously declared here}}
get { return i }
}
subscript (j: Int) -> Int { // expected-error{{invalid redeclaration of 'subscript'}}
get { return j }
}
}
func f4(a: Int) -> (Int) -> () { return { b in () } }
func f5(a: Int) -> (b: Int) -> () { return { b in () } }
func testFunctions(i: Int, x: X) {
f4(i)(i)
f4(i)(b: i) // expected-error{{extraneous argument label 'b:' in call}} {{9-12=}}
f5(i)(i) // expected-error{{missing argument label 'b:' in call}} {{9-9=b: }}
f5(i)(b: i)
}
struct Y {
func m0(a: Int) -> (Int) -> () { return { b in () } }
func m1(a: Int) -> (b: Int) -> () { return { b in () } }
func m2(a: Int) -> (Int, Int) -> () { return { b, c in () } }
func m3(a: Int) -> (b: Int, c2: Int) -> () { return { b, c in () } }
subscript (x: Int) -> Int {
get { return x }
}
subscript (y y: String) -> String {
get { return y }
}
}
func testMethods(i: Int, x: Y) {
x.m0(i)(i)
x.m0(i)(b: i) // expected-error{{extraneous argument label 'b:' in call}} {{11-14=}}
x.m1(i)(i) // expected-error{{missing argument label 'b:' in call}} {{11-11=b: }}
x.m1(i)(b: i)
x.m2(i)(i, c: i) // expected-error{{extraneous argument label 'c:' in call}} {{14-17=}}
x.m2(i)(i, i)
x.m3(i)(b: i, i) // expected-error{{missing argument label 'c2:' in call}} {{17-17=c2: }}
x.m3(i)(b: i, c2: i)
}
func testSubscripts(i: Int, s: String, x: Y) {
var i2 = x[i]
var i3 = x[x: i] // expected-error{{cannot subscript a value of type 'Y' with an index of type '(x: Int)'}}
// expected-note @-1 {{overloads for 'subscript' exist with these partially matching parameter lists: (Int), (y: String)}}
var s2 = x[y: s]
var s3 = x[s] // expected-error{{cannot convert value of type 'String' to expected argument type 'Int'}}
}
// Operators
func +(_ a: String, // expected-warning{{extraneous '_' in parameter: 'a' has no keyword argument name}}{{8-10=}}
b b: Double) { } // expected-error{{operator cannot have keyword arguments}} {{8-10=}}
func +(a: Double, b: String) -> (Int) -> (d: Int) -> () {
return { c in { e in () } }
}