| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 
 | // RUN: %target-typecheck-verify-swift
// RUN: %empty-directory(%t)
// RUN: %target-swift-frontend -primary-file %s %S/Inputs/composition_extension_usage.swift -emit-module-path %t/P-partial.swiftmodule -module-name M -enable-testing
// RUN: %target-swift-frontend -primary-file %S/Inputs/composition_extension_usage.swift %s -emit-module-path %t/S-partial.swiftmodule -module-name M -enable-testing
// RUN: %target-swift-frontend -merge-modules -emit-module %t/P-partial.swiftmodule %t/S-partial.swiftmodule -o %t/M.swiftmodule
// https://github.com/apple/swift/issues/53628
protocol P1 {}
protocol P1_1 : P1 {
  func p1_1()
}
protocol P2 {}
extension P1 & P1_1 where Self : P2 {
  // expected-warning@-1 {{extending a protocol composition is not supported; extending 'P1' instead}}
  // expected-note@-2 {{did you mean to extend the most specific type 'P1_1' instead?}} {{11-20=P1_1}}
  func p1_1() {}
}
extension P1_1 & P1 where Self : P2 {
  // expected-warning@-1 {{extending a protocol composition is not supported; extending 'P1_1' instead}} {{11-20=P1_1}}
  func p1_1_alt() {}
}
typealias T1 = P1 & P1_1
extension T1 {
  // expected-warning@-1 {{extending a protocol composition is not supported; extending 'P1' instead}}
  // expected-note@-2 {{did you mean to extend the most specific type 'P1_1' instead?}} {{11-13=P1_1}}
  func t1() {}
}
typealias T2 = T1
extension T2 {
  // expected-warning@-1 {{extending a protocol composition is not supported; extending 'P1' instead}}
  // expected-note@-2 {{did you mean to extend the most specific type 'P1_1' instead?}} {{11-13=P1_1}}
  func t2() {}
}
typealias T3 = P1_1 & P1
extension T3 { // Ideally, we should emit a warning here but the current implementation doesn't do that.
    func t3() {}
}
 |