blob: 83414a04ace38a34e0f30f8dfa46afa47aae0cfd [file] [log] [blame]
// RUN: %target-typecheck-verify-swift -typecheck -swift-version 4 %s -verify
// RUN: %target-typecheck-verify-swift -typecheck -swift-version 4 -debug-generic-signatures %s > %t.dump 2>&1
// RUN: %FileCheck %s < %t.dump
protocol P0 { }
protocol Q0: P0 { }
protocol P1 {
associatedtype AssocP1: Q0
func getAssocP1() -> AssocP1
}
protocol P2 : P1 {
associatedtype AssocP2: P1
func getAssocP2() -> AssocP2
}
protocol P3 {
associatedtype AssocP3: P0
func getAssocP3() -> AssocP3
}
protocol P4: P3 { }
protocol P5 : P4 {
associatedtype AssocP5 where AssocP3: Q0
}
func acceptP0<T: P0>(_: T) { }
func acceptQ0<T: Q0>(_: T) { }
func acceptP1<T: P1>(_: T) { }
func acceptP2<T: P2>(_: T) { }
func acceptP3<T: P3>(_: T) { }
func testPaths1<T: P2 & P4>(_ t: T) {
// CHECK: Conformance access path for T.AssocP2.AssocP1: P0 is τ_0_0: P2 -> τ_0_0.AssocP2: P1 -> τ_0_0.AssocP1: Q0 -> τ_0_0: P0
acceptP0(t.getAssocP2().getAssocP1())
// CHECK: Conformance access path for T.AssocP3: P0 is τ_0_0: P4 -> τ_0_0: P3 -> τ_0_0.AssocP3: P0
acceptP0(t.getAssocP3())
}
func testPaths2<U: P2 & P4>(_ t: U) where U.AssocP3 == U.AssocP2.AssocP1 {
// CHECK: Conformance access path for U.AssocP3: P0 is τ_0_0: P4 -> τ_0_0: P3 -> τ_0_0.AssocP3: P0
acceptP0(t.getAssocP2().getAssocP1())
}
func testPaths3<V: P5>(_ v: V) {
// CHECK: Conformance access path for V.AssocP3: P0 is τ_0_0: P5 -> τ_0_0.AssocP3: Q0 -> τ_0_0: P0
acceptP0(v.getAssocP3())
// CHECK: Conformance access path for V.AssocP3: Q0 is τ_0_0: P5 -> τ_0_0.AssocP3: Q0
acceptQ0(v.getAssocP3())
}
protocol P6Unordered: P5Unordered { // expected-note{{conformance constraint 'Self.A': 'P0' implied here}}
associatedtype A: P0 // expected-warning{{redundant conformance constraint 'Self.A': 'P0'}}
// expected-warning@-1{{redeclaration of associated type 'A'}}
}
protocol P5Unordered {
associatedtype A: P0 // expected-note{{'A' declared here}}
func getA() -> A
}
func testUnorderedP5_P6<W: P6Unordered>(_ w: W) {
// CHECK: Conformance access path for W.A: P0 is τ_0_0: P6Unordered -> τ_0_0: P5Unordered -> τ_0_0.A: P0
acceptP0(w.getA())
}