Files
swift-mirror/test/Sema/composition_extension.swift
Hamish Knight 751e68177c [test] Remove uses of -sil-merge-partial-modules
Replace with -merge-modules, which means we can
also remove the now redundant
`-disable-diagnostic-passes` &
`-disable-sil-perf-optzns` options.
2020-07-01 23:14:50 -07:00

47 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 SR11227 -enable-testing
// RUN: %target-swift-frontend -primary-file %S/Inputs/composition_extension_usage.swift %s -emit-module-path %t/S-partial.swiftmodule -module-name SR11227 -enable-testing
// RUN: %target-swift-frontend -merge-modules -emit-module %t/P-partial.swiftmodule %t/S-partial.swiftmodule -o %t/SR11227.swiftmodule
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() {}
}