mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
49 lines
1.7 KiB
Swift
49 lines
1.7 KiB
Swift
// 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() {}
|
|
}
|