mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
If a function's parameter or return types involve nominal types that have been moved across modules using @_originallyDefinedIn, we must take care to always mangle the opaque result type's name using the original module names and not the current module names. This was a problem with DWARF mangling, which normally disables @_originallyDefinedIn for other purposes. Make sure to always temporarily re-enable it when mangling an opaque result type. Fixes rdar://problem/93822207.
31 lines
1.1 KiB
Swift
31 lines
1.1 KiB
Swift
// RUN: %empty-directory(%t)
|
|
|
|
// RUN: %target-swift-emit-module-interface(%t/CoreVegetable.swiftinterface) %S/Inputs/CoreVegetable.swift -disable-availability-checking
|
|
// RUN: %target-swift-typecheck-module-from-interface(%t/CoreVegetable.swiftinterface)
|
|
// RUN: %target-swift-emit-module-interface(%t/CoreChef.swiftinterface) %s -module-name CoreChef -I %t -disable-availability-checking -DLIB
|
|
// RUN: %target-swift-typecheck-module-from-interface(%t/CoreChef.swiftinterface) -module-name CoreChef -I %t -disable-availability-checking
|
|
|
|
// Also build the module itself with -g to exercise debug info round tripping.
|
|
// RUN: %target-swift-frontend -emit-ir -g %s -I %t -disable-availability-checking
|
|
|
|
// RUN: %FileCheck %s < %t/CoreChef.swiftinterface
|
|
|
|
// REQUIRES: OS=macosx
|
|
import CoreVegetable
|
|
|
|
public protocol Soup {}
|
|
|
|
public struct VegetableSoup : Soup {}
|
|
|
|
public protocol Chef {
|
|
associatedtype Food
|
|
|
|
func cookSoup(_: Vegetable) -> Food
|
|
}
|
|
|
|
public struct SoupChef : Chef {
|
|
public func cookSoup(_: Vegetable) -> some Soup { VegetableSoup() }
|
|
}
|
|
|
|
// CHECK-LABEL: public typealias Food = @_opaqueReturnTypeOf("$s8CoreChef04SoupB0V04cookC0yQr0aC09VegetableVF", 0) __
|