| // 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()) |
| } |